# Aicroprocessors

Intel80186 -Intel8086 - Z80 - Intel8085 Pentium - Intel80486 - Intel80386 - Intel80286

المعرجة والتحارية والتحارية

تالیف حمد ادامیمالی

الُّذِيمِ حمد إبراهيم العدوي انتقادة رئيس قسم الاتصالات والإل<sup>يكتو</sup>رانيات

علية المضائمة - جامعة حلوان

الله الدوارة الأستورات القافية

# المعالجات الدقيقة

# Microporocessors

Intel 80186 – Intel 8086 – Intel 8085

Pentium 8 – Intel 80486 – Intel 80386

Intel 80286

البرمجة ... والمواجعة ... والتطبيق

ا.د. محمد إبراهيم العدوس أستاذ ورئيس قسم الاتصالات والإلكترونيات كلية الهندسة \_ جامعة حلوان

الطبعة الأولى 2000 م المعالجات الدقيقة تأليف د. محمد إبراهيم العدوس رقم الإيداع

> 2000/3149 I.S.B.N 977-282 -076-5

لا يجوز نشر أى جزء من هذا الكتاب أو اختزان مادته بطريقة الاسترجاع أو نقله على أى نحو أو بأى طريقة سواء أكانت إلكترونية أو ميكانيكية أو خلاف ذلك إلا بجوافقة الناشر على هذا كتابة ومقدماً.

حقوق الطبع والاقتباس والترجمة والنشر محفوظة للدار الدولية للاستثمارات الثقافية ش. م. م.

8 إبراهيم العرابس ـ النزفة الجديدة ـ مصم الجحيدة ـ القا فــرة ــج.م.ع.

ص.ب؛ 5599 مليو بوليس غرب/ القامرة ـ تليفون؛ 2957655/2972344 فاكس ؛ 2957655 فاكس

# المحتويات

| 5      | ١. | W, | ١Ķ |
|--------|----|----|----|
| الكتاب | L  | ض  | 2  |

| 1  | القصل الأول : عصر الميكروبروسيسور             |
|----|-----------------------------------------------|
| 3  | 1−1 عصر الميكروبروسيسور                       |
| 5  | 1-2 أين يقع المعالج في داخل الميكروكومبيوتر ؟ |
| 6  | 1-2-1 الذاكرة                                 |
| 7  | 1-2-2 وحداث الأدخال والأخراج                  |
| 8  | 1-2-3 وحدة المعالجة المركزية                  |
| 8  | ماذا تعنى هذه الألفاظ ؟ $-1$                  |
| 8  | 1-3-1 الميكروكومبيوتر والميكروبروسيسور        |
| 9  | software and hardware البرمجة والبناء         |
| 10 | 1–3–3 الأمر والبرنامج                         |
| 10 | 1-3-1 لغات البرمجة                            |
| 12 | 1-3-1 البت والبايت                            |
| 12 | 1–4 تمارین                                    |
| 15 | الفصل الثاني : البناء المعماري للمعالج        |
| 17 | 1-2 مقدمة                                     |
| 17 | 2-2 المهام الأساسية المطلوبة من المعالج       |
| 18 | 2-2 أجزاء المعالج الأساسية                    |
| 18 | 2-4 المسجلات والعدادات في شريحة المعالج       |
| 19 | accumulator مسجل التراكم                      |
| 20 | 2-4-2 عداد البرنامج program counter           |
|    | 2-4-2 مسجل وفاكك شفرة الأوامر                 |
| 20 | instruction reguster & decoder                |
| 21 | status register مسجل الحالة 4-4-2             |
| 21 | zero flag علم الصفر 1-4-4                     |
| 21 | 2-4-4 علم الأشارة sign flag                   |
| 21 | 3-4-4-2 علم الحمل carry flag                  |
| 22 | 9-4-4 علم الباريتي parity flag                |
|    | 2-4-4 علم الحمل النصفي أو البيني              |

| 22 | half carry flag                                    |
|----|----------------------------------------------------|
|    | 2-4-2 مسجل مؤشر المكدسة                            |
| 23 | stack pointer register                             |
| 23 | 2-4-6 المسجلات عامة الأغراض                        |
| 25 | 2-5 نظرة خارجية على شرائح المعالج                  |
| 26 | 1-5-2 مسار العناوين address bus                    |
| 26 | 2-5-2 مسار البيانات data bus                       |
| 27 | 2-5-2 خطوط التحكم control lines                    |
| 30 | 6-2 شرائح المعالجات ذات 8 بت 8 bit microprocessors |
| 30 | $-6\overline{-2}$ الشريحة Intel8085                |
| 30 | 2-6-2 المعالج Z80                                  |
| 33 | 2-7 تمارین                                         |
|    |                                                    |
| 35 | القصل الثالث : برمجة المعالج                       |
| 37 | 1-3 مقدمة                                          |
| 37 | 2-3 لغات الحاسب                                    |
| 37 | 3-3 ما هو الأمر ؟                                  |
| 38 | 3-4 ما هو البرنامج ؟                               |
| 39 | 3–5 كيف يقوم المعالج بتنفيذ البرنامج ؟             |
| 40 | 3-6 طريقة كتابة البرنامج للمعالج                   |
| 40 | 1-6-3 الشفرات الثنائية binary codes                |
| 40 | 2-6-3 الشفرات الستعشرية hexadecimal codes          |
| 42 | 3-6-3 الشفرات الحرفية mnemonics codes              |
| 44 | 7–3 اللغات ذات المستوى العالى high level languages |
| 45 | 3–8 خطوات كتابة برنامج بلغة الأسمبلي               |
| 48 | 3–9 تمارین                                         |
|    | ·                                                  |
| 51 | الفصل الرابع: برمجة المعالج Intel8085              |
| 53 | 1–4 مقدمة                                          |
| 53 | 2-4 مجموعة أوامر الأنتقال Transfer instructions    |
| 53 | 1−2−4 الأمر MOV                                    |
| 55 | 2-2-4 الأمر MVI                                    |
| 57 | 4–2–4 الأمر LXI                                    |
| 60 | 4–2–4 الأمران STA و LDA                            |
| 61 | 4−2−4 الأمران LHLD و SHLD                          |

| 62  | 4–3 تمارین                                                    |
|-----|---------------------------------------------------------------|
| 63  | 4-4 مجموعة أوامر الحساب arithmatic instructions               |
| 64  | 4–4–1 الأمران ADD و SUB                                       |
| 66  | 4–4–2 الأمران ADI و SUI                                       |
| 67  | 4–4–3 الأمران ADC و SBB                                       |
| 69  | 4–4–4 الأمران INR و DCR                                       |
| 71  | 4–4–5 الأمران INX و DCX                                       |
| 71  | 4–5 تمارین                                                    |
| 73  | jump instructions مجموعة أوامر القفز $-4$                     |
| 73  | 4-6-1 القفز غير المشروط unconditional jump                    |
| 73  | 4—6—2 القفز المشروط conditional jump                          |
| 75  | 4-7 مهمة أخرى للأسمبلر                                        |
| 75  | 4–7–1 الأمر والمعاملات                                        |
| 77  | 2-7-4 التعليق comment                                         |
| 78  | 3-7-4 العلامة label                                           |
| 79  | 8–4 أوامر الأدخال والأخراج input output instructions          |
| 83  | 9–4 مجموعة أوامر المنطق logic instructions                    |
| 85  | 4-10 كيفية الأتصال بالذاكرة Memory addressing                 |
| 85  | 1-10-4 الطريقة المباشرة direct method                         |
| 85  | 4-20-2 الطريقة غير المباشرة indirect method                   |
| 95  | 4–11 تمارین                                                   |
|     |                                                               |
| 99  | الفصل الخامس: برمجة المعالج 280                               |
| 101 | 1-5 مقدمة                                                     |
| 101 | 2-5 مجموعة أوامر الأنثقال transfer instructions               |
| 101 | 5-2-1 نقل معلومة من مسجل الى مسجل آخر                         |
| 102 | 5-2-2 تحميل مسجل بثابت أو معلومة فورية                        |
| 105 | 5-2-3 نقل معلومة من مسجل الى الذاكرة والعكس                   |
| 106 | 1-3-2-5 الطريقة المباشرة direct addressing                    |
|     | 5-2-3-2 الطريقة غير المباشرة                                  |
| 107 | indirect addressing                                           |
| 109 | 3-3-2-5 طريقة الفهرسة indexed addressing                      |
| 109 | 5−3 تمارين<br>5−4 مجموعة أوامر الحساب arithmatic instructions |
| 110 | arithmatic instructions أو امر الحساب                         |

| 110 | 5–4–1 الأمران ADD و SUB                             |
|-----|-----------------------------------------------------|
| 113 | 5–4–5 الأمران ADC و SBC                             |
| 115 | 5–4–3 الأمران INC و DEC                             |
| 115 | 5-4-4 العمليات الحسابية على أزواج المسجلات          |
| 117 | 5-4-5 أمر المقارنة compare instruction              |
| 118 | 5–5 تمارین                                          |
| 119 | 6-5 مجموعة أوامر القفز jump instructions            |
| 119 | 1–6–5 القفز غير المشروط unconditional jump          |
| 120 | 2-6-5 القفز المشروط conditional jump                |
| 120 | 5—6—5 القفز النسبي relative jump                    |
| 121 | . 5–7 مهمة أخرى للأسمبلر                            |
| 121 | ة أو امر الأدخال والأخراج input output instructions |
| 122 | 1-8-5 أو امر الأدخال input instructions             |
| 123 | 2-8-5 أوامر الأخراج output instructions             |
| 123 | 9-5 مجموعة أو امر المنطق logic instructions         |
| 141 | 5—10 تمارین                                         |
|     |                                                     |
| 145 | القصل السادس: المعالج من البداية حتى النهاية        |
| 147 | 16 مقدمة                                            |
| 147 | 2-6 الجمع الثنائي binary addition                   |
| 148 | 1−2−6 دائرة نصف المجمع half adder                   |
| 149 | full adder دائرة المجمع الكامل 2-2-6                |
| 150 | 6-3 الطرح الثنائي binary subtraction                |
| 154 | arithmatic and logic unit والمنطق 4-6               |
| 157 | 5-6 مسجل التراكم accumulator register               |
| 161 | 6-6 اضافة ذاكرة للمعالج الأفتراضي                   |
| 165 | 6–7 تمارین                                          |
|     |                                                     |
| 167 | الفصل السابع: أساسيات مواجهة المعالج                |
| 169 | 1-7 مقدمة                                           |
| 169 | 2-7 فصل buffering خطوط المعالج                      |
| 169 | 7-2-1 ماذا نعنى بكلمة فصل ؟                         |
| 170 | 7-2-2 متى نحتاج لفصل خطوط المعالج ؟                 |
| 172 | 3-7 البوابات ثلاثية المنطق tristate logic gates     |

| 174 | 7-3-7 بوابات المنطق الثثائي                      |
|-----|--------------------------------------------------|
| 175 | 7-3-7 البوابات ثلاثية المنطق                     |
| 177 | الماسك latch                                     |
| 178 | 7-5 بعض الشرائح التي تستخدم في فصل المسارات      |
| 178 | 7-5-7 الشريحة 74244 عازل ثماني ثلاثي المنطق      |
|     | 7-5-2 الشريحة 74245 فاصل ذو ثمان بتات ثنائ       |
| 179 | الأتجاه ثلاثى المنطق                             |
| 181 | 75- الشريحة 74374 فاصل ماسك ذو ثمان بتات         |
| 182 | 7–6 تمارین                                       |
| 183 | القصل الثَّامن : قصل مسارات المعالج              |
| 185 | 1-8 مقدمة                                        |
| 186 | 8-2 لماذا مسار العناوين ؟                        |
| 188 | 8–3 لماذا مسار التحكم ؟                          |
| 190 | 8–4 تهيئة مسارات المعالج 8085 لعملية المواجهة    |
| 191 | 8–4–1 مسار العناوين للمعالج 8085                 |
| 192 | 8-4-2 مسار البيانات للمعالج 8085                 |
| 194 | 8–4–3 مسار التحكم للمعالج 8085                   |
| 196 | 8–5 تهيئة مسارات المعالج Z80 لعملية المواجهة     |
| 200 | 8–6 ثمارین                                       |
| 203 | الفصل التاسع : مواجهة الذاكرة memory interfacing |
| 205 | 1-9 مقدمة                                        |
| 206 | 9-2 أساسيات بناء ذاكرة الحاسب                    |
| 210 | 9–3 كيف سنوصل الذاكرة على المعالج ؟              |
| 210 | 9-3-1 مثال توضيحي                                |
| 210 | 9–3–2 نظام بلوكات الذاكرة                        |
| 213 | 9–3–3 بناء البلوكات من شرائح                     |
| 220 | 9–4 تمارین                                       |
| 221 | الفصل العاشر : الأدخال والأخراج                  |
| 223 | 1-10 مقدمة                                       |
| 225 | 10-2 طرق ارسال واستقبال المعلومات الرقمية        |
|     | 10–3 الطريقة الأولى من طرق الأدخال والأخراج      |

| 227 | باستخدام الأمرين IN و OUT                         |
|-----|---------------------------------------------------|
| 228 | 10-3-10 دائرة بوابة الأخراج output port           |
| 234 | 2-3-10 دائرة بوابة الأدخال input port             |
|     | 10–4 الطريقة الثانية من طرق الإدال والإخراج       |
| 236 | باستخدام خريطة الذاكرة memory map                 |
| 238 | 10-4-1 دائرة بوابة الأخراج باستخدام خريطة الذاكرة |
| 239 | 10-4-1 دائرة بوابة الأدخال باستخدام خريطة الذاكرة |
| 241 | 10-5 اليو ابات القابلة للبرمجة                    |
| 242 | 10-5-10 تركيب الشريحة 8255A                       |
| 244 | 2-5-10 برمجة الشريحة 8255A                        |
| 248 | 3-5-10 حالات modes تشغيل الشريحة 8255A            |
| 249 | 1−3−5−10 الحالة صفر mode zero                     |
| 252 | 2-3-5-10 الحالة واحد mode one                     |
| 258 | 3-3-5-10 الحالة اثنين mode two                    |
| 258 | 10−6 تمارين                                       |
|     |                                                   |
| 261 | الفصل الحادي عشر: التحكم في إشارة مرور            |
| 263 | 1-11 مقدمة                                        |
| 263 | 11–2 تركيب الدائرة                                |
| 264 | 11–2–11 مثال توضيحي                               |
| 266 | 11–3 الأطراف الأخرى للمعالج 8085                  |
| 266 | 11–3–11 أشارات الترامن clock                      |
| 267 | 11-3-2 بدأ واعادة التشغيل                         |
| 269 | 11−3−1 الطرفان HOLD و HLDA                        |
| 270 | 11-3-11 الطرف READY                               |
| 271 | 11–3–5 طرفي الحالة SO و SI                        |
| 272 | · 11-3-6 أطراف المقاطعة ِ                         |
| 272 | - 11−3−11 الطرفان SID و SOD                       |
| 272 | 11−4 الأطراف الأخرى للمعالج Z80                   |
| 272 | -11 أطراف المقاطعة                                |
| 273 | 2-4-11 الطرف RFSH                                 |
| 273 | 11–4–1 الطرف HALT                                 |
| 273 | · 4-11 الطرف WAIT                                 |
| 274 | 11–4–1 الطرف M1                                   |
|     |                                                   |

.

| 274 | 6-4-11 الطرف CLK                                          |
|-----|-----------------------------------------------------------|
| 274 | 11–5 إشارات المرور                                        |
| 282 | 11–6 تمارین                                               |
| 283 | الفصل الثاني عشر: البرامج الفرعية subroutines             |
| 285 | 1-12 مقدمة                                                |
| 285 | 12–2 ما هو البرنامج الفرعى ؟                              |
| 287 | 12-3 كيف يعود المعالج الى نفس المكان الذي خرج منه ؟       |
| 291 | 4-12 حساب أزمنة التأخير                                   |
| 294 | 12−5 تمارین                                               |
| 297 | الفصل الثالث عشر: المقاطعة interrupt                      |
| 299 | 1-13 مقدمة                                                |
| 299 | 13−2 طريقة طرق الأبواب لخدمة الأجهزة المحيطة polling      |
| 301 | 3-13 المقاطعة                                             |
| 302 | 13-4 مقاطعة المعالج 8085                                  |
| 303 | 1-4-13 الخطوط RST7.5 و RST6.5 و RST5.5                    |
| 312 | 2-4-13 الخط TRAP                                          |
| 313 | 3-4-13 الخط INTR                                          |
|     | 13-4-4 كيف يتم تحديد العنوان الذي سيتم القفز اليه         |
| 314 | في حالة المقاطعة INTR ؟                                   |
| 315 | 5−13 مقاطعة المعالج Z80                                   |
| 315 | 1-5-13 الخط NMI                                           |
| 317 | 2-5-13 الخط INT                                           |
| 321 | 13-6 تمارین                                               |
| 323 | الفصل الرابع عشر: التركيب الهيكلي للمعالج intel/8086/8088 |
| 325 | 1-14 مقدمة                                                |
| 326 | 14-2 نظرة داخلية على محتويات المعالج 8086/8088            |
| 327 | 14–3 نظرة تفصيلية على مسجلات المعالج 8086/8088            |
| 329 | -14 المسجلات عامة الأغراض                                 |
| 332 | 14-3-2 المسجلات الخاصة                                    |
| 332 | 4-14 تجزىء الذاكرة memory segmentation                    |
| 335 | 14-14 مسجل تجزىء البرامج CS                               |

| 335 | 2-4-14 مسجل تجزىء البيانات DS                  |
|-----|------------------------------------------------|
| 335 | 4-14 مسجل تجزىء المكدسة SS                     |
| 336 | 4-4-14 مسجل التجزىء الإضافي ES                 |
| 336 | 14-4-5 مسجل الأعلام SR                         |
| 338 | 5-14 طرق العنونة addressing modes              |
| 339 | 1-5-14 عنونة المسجل                            |
| 339 | 14-5-2 العنونة الفورية                         |
| 340 | 14-5-3 العنونة المباشرة                        |
| 340 | 14–5–4 العنونة غير المباشرة                    |
| 341 | 14-5-5 عنونة القاعدة زائد الفهرسة              |
| 341 | 14-5-6 العنونة النسبية                         |
| 342 | 14–6 تمارین                                    |
| 345 | الفصل الخامس عشر: برمجة المعالج intel8086/8088 |
| 347 | 1-15 مقدمة                                     |
| 347 | 15-2 خطوات كتابة وتنفيذ برامج لغة التجميع      |
| 348 | 15-3 مكونات برنامج الأسمبلي                    |
| 353 | 15-4 أو امر لغة الأسميلي                       |
| 353 | 15-5 مجموعة أوامر الانتقال                     |
| 356 | 6-15 الديبجر debugger                          |
| 356 | 15-15 إظهار محتويات المسجلات                   |
| 357 | 15-6-2 عرض أوامر الأسمبلي ابتداء من عنوان معين |
| 358 | 15-6-5 عرض محتويات جزء من الذاكرة              |
| 358 | 15-6-4 تنفيذ البرنامج حتى عنوان معين           |
|     | 15-6-5 متابعة تتفيذ البرنامج عن طريق تنفيذ     |
| 359 | عدد n من الخطوات                               |
| 359 | 15-6-6 تغيير محتويات عنوان في الذاكرة          |
| 360 | 15–6–7 الخروج من الديبجر                       |
| 360 | 7-15 تمارین                                    |
| 361 | 15—8 أوامر القفز                               |
| 361 | 15-8-15 القفز غير المشروط                      |
| 361 | 15-8-15 القفز المشروط                          |
| 363 | 3-8-15 الأمر Loop                              |
| 364 | 15–9 أول خطوات التعامل مع الذاكرة              |
|     |                                                |
|     | ر                                              |
|     |                                                |

| 364 | -15الطريقة المباشرة                                   |
|-----|-------------------------------------------------------|
| 364 | 15-9-2 الطريقة غير المباشرة                           |
| 366 | 15-15 أوامر الحساب                                    |
| 374 | 15–11 أوامر المنطق                                    |
| 376 | 15–12 أوامر الإزاحة والدوران                          |
| 383 | 13–15 تمارین                                          |
|     |                                                       |
| 385 | الفصل السادس عشر: مواجهة المعالج 8086/8088            |
| 387 | 1-16 مقدمة                                            |
| 387 | 16-2 الوظائف المختلفة لأطراف الشريحة 8086/8088        |
| 393 | 1-2-16 نبضات الساعة                                   |
| 393 | 16–3 عزل مسارات المعالج 8086                          |
| 394 | 16–4 مواجهة الشريحة 8086/8088 مع الذاكرة              |
| 399 | 16–5 الإىخال والإخراج من وإلى المعالج 8086/8088       |
| 402 | 16-6 شريحة مواجهة أوحة المفاتيح القابلَة للبرمجة 8279 |
| 404 | 16-7 المؤقت القابل للبرمجة 8254                       |
| 411 | 168 الاتصالات القابلة للبرمجة 8251                    |
| 413 | 16–9 الاتصال المباشر مع الذاكرة 8237A                 |
| 414 | 16−16 المواجهة مع المعالجات الحسابية المساعدة 80x87   |
| 415 | 11-16 تمارین                                          |
|     |                                                       |
| 417 | الفصل السابع عشر: ثم ماذا ؟? What else                |
| 419 | 1-17 مقدمة                                            |
| 419 | 2-17 المعالج 80186                                    |
| 421 | 17−2−17 أطراف المعالج 80186                           |
| 425 | 17−2−2 برمجة المعالج 80186                            |
| 425 | 3-17 المعالج 80286                                    |
| 426 | -17 التركيب الهيكلي للمعالج 80286                     |
| 428 | 4-17 المعالج 80386                                    |
| 428 | 17-4-17 التركيب الهيكلي للمعالج 80386                 |
| 428 | 2-4-17 تنظيم الذاكرة للمعالج 80386                    |
| 431 | 17-4-3 نظام الإدخال والخراج في المعالج 80386          |
| 431 | 4-4-17 أطراف المعالج 80386                            |
| 433 | 71-4-5 مسجلات المعالج 80386                           |

·

| 434 | 5-17 الذاكرة المخباة Cache memory            |
|-----|----------------------------------------------|
| 435 | 6-17 المعالج 80486                           |
| 436 | 7-17 انسيابية الأوامر Instruction pipelining |
| 441 | 8-17 سلسلة معالجات بنتيم Pentium Processors  |
| 443 | 9-17 المعالج بنتيم برو Pentium Pro Processor |
| 445 | 17-17 تمارین                                 |
| 447 | الملحق الأول: الحساب الرقمى                  |
| 455 | مراجع الكتاب                                 |

### إهداء إلى اللغة العربية

ظلموك فقالوا إنك لست لغة علوم . . . مع أنك والله مثل الإنجليزية والكثير من اللغات الأوربية (أربعة وعشرون حرفا أو تزيد قليلا) . . . ويتكلم بك عدد لا بأس به مثلها تماما . . . أين أنت من اليابانية التي لها أربعة آلاف حرفا أو تزيد . . . ولكنها قوية بقوة أهلها . . . وعزيزة بعزتها عند أهلها . . . ولكن يكفيك فخرا أنك لغة القرآن الكريم المحفوظ من قبل الله عز وجل . . . وبذلك ضمنت الحفظ والصون إلى الأبد . . . كان من الممكن أن تكوني في عالم النسيان في ظل عقد الخواجه التي يعيشها أبنائك الآن لولا حفظك بالقرآن الكريم . . .

حمدا شه

### عرض الكتاب

عندما ظهر الترانزيستور في أواخر الأربعينات الميلادية أحدث ما يشبه الشورة في مجال الإلكترونيات بحيث أنه أصبح الوحدة الأساسية لبناء أي دائسرة إلكترونية. بظهور مكبر العمليات operational amplifier في منتصف الستينات كدائرة تكاملية رخيصة التكاليف، صغيرة الحجم، سلبت الأضواء من الترانزيستور ودخل مكبر العمليات كوحدة أساسية جديدة في الكثير من التطبيقات والدوائر الإلكترونية. في منتصف السبعينات تالق نجم الميكروبروسيسور (المعالج) وانتشر استخدامه في الكثير من الدوائر والأنظمة الإلكترونية وأنظمة التحكم، حتى أنك تجده الآن في السيارة يتحكم في الكثير من متغيراتها، وفسي الصاروخ يتحكم في تشغيله، بل في المبيد الطفل يتحكم في الكثير من أدائها.

موضوع المعالجات من الموضوعات التي يصعب جدا أن تجمع أو تنتهى في مؤلف أو كتاب واحد يرضى جميع القراء وذلك نظرا التشعبات الكثيرة التي يمكن أن يتشعب إليها هذا الموضوع ، وما من قارئ يقرأ كتابا في هذا الموضوع و إلا ويقول ليت المؤلف أضاف كذا وحنف كذا تبعا لنظرته واهتماماتك الخاصة . هناك مثلا من القراء من يهتم بالبرمجة فقط software ولا يهتم كثيرا بموضوعات المواجهة والبناء على حساب البرمجة .

لقد راعينا في هذا الكتاب أن يفي بقدر الإمكان باحتياجات الكثير من القراء ، فهذا الكتاب يقدم القارئ الكثير من شرائح المعالجات الشائعة الاستخدام ذات 8 و 16 و 32 بت وذلك حتى يجد أي مستخدم لهذه الشرائح ما يفيده وتكون الفرصة متاحب لمن يرغب في المقارنة بين أكثر من شريحة ويشهد تطبور المعالجات عبر الأجيال المختلفة . يحتوى الكتاب أيضا على فصل خاص ببرمجة كبل شريحة على حدة من الشرائح 8085 و 280 و 8086 من خلال شرح ميسر وأمثلة عديدة على أوامر كل شريحة وذلك في الفصول 4 و 5 و 15 وذلك بعد أن سبقت هذه الفصول بغصل كمقدمة عن المعالجات بصفة عامة وما هو دورها في الميكروكومبيوتر وهو الفصل الأول ، ثم تلا ذلك فصل خاص بالتركيب الداخلي الميكروبروسيسور بصفة عامة على ضوء الوظائف المطلوبة منه وهو الفصل الثاني حيث انتهى هذا الفصل بعرض التركيب الداخلي للمعالجين 8085 و 280 ، وبعد ذلك قدم الفصل الثالث عرضا المغات البرمجة وكيفية برمجة المعالج . كتطبيق على الفصول الخمسة الأولى من الكتاب يحتوى الفصل السادس على كتطبيق على الفصول الخمسة الأولى من الكتاب يحتوى الفصل السادس على عملية بناء لمعالج افتراضي hypothetical من البداية (ابتداء من دائرة نصف

المجمع) ثم الارتقاء بهذه الدائرة إلى أن يتم المصول على وحدة حساب ومنطق ثم توصيل هذه الوحدة مع مركم accumulator ثم توصيلها مع الذاكرة وعمل قائمة أوامر خاصة بهذه الوحدة لبرمجتها . بذلك ينتهى تقريبا جـزء مـهم مـن الكتاب وهو الجزء الخاص بالمقدمة وتركيب المعالجات ذات 8 بت وبرمجتها . يبدأ بعد ذلك الفصل السابع الذى يحتوى على بعض الأساسيات التي يجب الإلملم بها قبل الدخول في عمليات المواجهة مع المعالج ، مثل عمليات الفصل أو العنول buffering ومتى نحتاج إليها والمنطق الثلاثي أيضا ولماذا نحتاجه مسع عرض لبعض الشرائح التي تستخدم في ذلك . لمواجهة المعالج مع شرائح الذاكرة مثلا لابد من تهيئة المسارات الثلاثة (العناوين والبيانات والتحكم) والحصول عليها في صورة مناسبة لأى عملية مواجهة ، حيث يحتوى الفصىل الثامن على ذلك بالتفصيل . بعد عملية التهيئة للمسارات الثلاثة في الفصل الثامن يقددم الفصل التاسع كيفية توصيل الذاكرة على المعالج ثم يقدم الفصل العاشر كيفية توصيل المعالَج على بوابات أو منافذ الإنخال والإخراج وذلك بالطرق المختلفة . بانتهاء الفصل الحادى عشر يتم الانتهاء من دراسة الأجزاء الرئيسية اللازمة لبناء دوائر التحكم التى تستخدم المعالج ولذلك فإن الفصل الحادى عشر يقدم مثالا متكاملا بجزئي البرمجة والبناء لنظام التحكم في إشارة مرور في تقاطع رباعي وذلك كمثال يمكن تقليده في أي تطبيق آخر ، البرمجة المثقدمة المعالَّج تحتاج لبعـــض الموضوعات التي رأينا أن يفرد لكل منها فصل خاص بها ، من هذه الموضوعات موضوع البرامج الفرعية subroutines والذى أفرد له الفصل الثاني عشر ، ثم موضوع المقاطعة interrupt وقد خصص له الفصل الثالث عشر . المعالجات ذات 16 بت ويمثلها المعالج intel8086 قد فرضت نفسها على السوق فترة ليست بالقليلة متمثلة في الحاسبات XT . لذلك قد أفردنا لها أكثر من فصل ، فالفصل الرابع عشر يقدم تفاصيل التركيب الهيكلي لهذا المعالج ، والفصل الخامس عشر يقدم تفاصيل برمجة هذا المعالج حيث أن لغة التجميع لهذا المعالج تعتبر الأساس لكل المعالجات التالية . الفصل السادس عشر يقدم كيفية مواجهـــة هذا المعالج مع الدوائر الخارجية مثل الذاكرة وبوابات الإدخال والإخراج . وأخيرا يقدم الفصل السابع عشر فكرة مختصرة ولكننا نعتقد أنهها كافية عن المعالجات 80186 و 80286 و 80386 و 80486 وكذلك عائلة معالجات بنتيم الشهيرة في السوق هذه الأيام والتي تتوالى إصداراتها حيث نفاجاً بإصدار جديد منها كل ستة شهور تقريبا .

هذا الكتاب ككتاب دراسى text book يمكن تدريسه للمبتدئين فى تعلم موضوع المعالجات على فصلين دراسين متعاقبين (ساعتين لكل فصل أو 4 ساعات فسى فصل واحد) حيث يدرس فى الفصل الدراسى الأول المقدمة والفصول الخاصة ببرمجة المعالج والمعالج الافتراضى وفصل البرامج الفرعيسة وكذلك مبادئ

مواجهة المعالجات والتطبيق على ذلك بدراسة فصلى المواجهة مع الذاكرة وبوابات الإدخال والإخراج . في الفصل الدراسي الثاني يتم تدريس الفصل الخاص المقاطعة واستخدام المعالج في عمليات التحكم المختلفة أو في بناء نظام ميكر وكومبيوتر بسيط وبعدها يتم الانتقال إلى المعالجات ذات 16 بست لدراسة تركيبها الداخلي ويرمجتها ومواجهتها ثم يتم الانتقال إلى المعالجات الأخرى لأخذ فكرة سريعة عنها ومقارنتها بما سبقها من معالجات .

لابد أن يصاحب هذا المقرر ساعتين للمعمل أسبوعيا يقوم الطالب فيها بتطبيق كل ما تمت دراسته من برامج أو دوائر من خلال بعض التجارب التي توضع بدقـــة بحيث تتابع الدراسة النظرية للموضوع وتغطى جانبي البرمجة ودوائر مواجهــة

المعالج .

لكى تتم الفائدة يجب أن يكون القارئ لهذا الكتاب قد درس قدرا كافيا من الإلكترونيات الرقمية ابتداء من البوابات والدوائر المنطقية ، تبسيطها وطرق بناؤها ، ودوائر الجمع adders ، والمشفرات encoders ، والمنتخبات adders بناؤها ، ودوائر الجمع flip flops والمسجلات الإزاد shift registers والعدادات counters بأنواعها . كذلك فإنه من الأفضل (وليسس بضرورة) أن والعدادات تدرس مقررا عن مقدمة الحاسب وألم فيه بموضوعات الخوارزميات Algorithms وخرائط التدفق أو مخططات السير Flow charts والحلقات البرمجة والحلقات المستوى العالى حيث يتساوى فى ذلك الباسيك أو الباسكال أو ال

يمكن القارئ المهتم بأى نوع من أنواع المعالجات التى تم تناولها فى هذا الكتساب أن يتتبع الدراسة والتطبيق على هذا النوع فقط دون عناء كبير ودون أن يكون مضطرا لقراءة الكثير عن المعالجات الأخرى التى لا تهمه إن أراد ذلك ، حيث قد تم مراعاة ذلك فى خلال هذا الكتاب بقدر الإمكان مع العلم أن هناك فصولا تم عرض معظمها بصورة لا تعتمد على المعالج المستخدم مثل فصسول مواجهة

الذاكرة والإدخال والإخراج.

من الصعوبات التى واجهتنا فى إعداد هذا الكتاب والتى من المتوقع أنها تواجه أى شخص مهتم أو حريص على نشر وترجمة العلوم باللغة العربية هى ترجمة المصطلحات العلمية فى هذا المجالي ، إننا نقول أنها صعوبات ليسس لأن اللغة العربية عاجزة عن إيجاد لفظة عربية تؤدى معنى المصطلح ولكن لأن أفظ المصطلح الأجنبي قد فرض نفسه علينا نحن المشتغلين فى هذا المجال بحيث أصبح من الصعب أن نفلت منه ونلك راجع بالطبع للسبق الذى حققه الناطقون بلغة المصطلح ، ولذلك فقد حاولنا استخدام صورة المصطلح الأجنبية مكتوبة باللغة العربية والإنجليزية مع الترجمة العربية لمعنى المصطلح وذلك حتى نتيح باللغة العربية والإنجليزية مع الترجمة العربية لمعنى المصطلح وذلك حتى نتيح للقارئ فرصة التعرب في المصطلح وذلك حتى نتيح

microprocessor قد شاعت ترجمتها باللغة العربية بالمعالج الدقيق وأحيانا المعالج الصغرى ونحن استخدمنا الترجمة الأولى وفي معظم الأحيان نستخدم كلمة معالج فقط أو حتى كلمة بروسيسور أو ميكروبروسيسور كما يشيع النطق بها حتى تعم الفائدة ولا ننسى المصطلح الأجنبي .

وأخيرا وقبل أن أترك هذا المقام لابد من تقديم كلمات شكر وعرفان لكلم مسن ساعد ولو بالتشجيع في إنجاز هذا الكتاب الذي أخذ الكثير من الجهد . أخص بالشكر هذا الأستاذ الدكتور فريد عبد العزيز طلبة الأستاذ بكلية الهندسة جامعة عين شمس وعميد كلية التعليم الصناعي بالقاهرة الذي تابع وراجع وأبدى الآراء الصنائبة بالذات في المراحل الأولى من الكتاب . كذلك أتوجه بالشكر إلى زمسلاء لي في الكلية التقنية ببريدة بالمملكة العربية السعودية كانوا وراء فكرة التفكير في وضع هذا الكتاب باللغة العربية وأخص بالذكر منهم المهندس صلاحال الشبعان وآخرون كثيرون . أتوجه بالشكر أيضا إلى زميلي د.هشام عبد المنعم كشك الذي مارس تدريس هذا الكتاب وكانت له الكثير من الآراء والتوجيهات . كذلك أتوجه بالشكر إلى الكثير من الطلاب بقسم الإلكترونيات بهندسة حلوان الذين مارست معهم تدريس هذه المحتويات لمدة خمس سنوات وكم كنت أتلقى منهم التوجيهات وأو لادى الذين صبروا على كثيرا وتحملوا منى الكثير على طول فترات انشغالي وأعداد هذا الكتاب .

إن تجربة تأليف كتاب باللغة العربية ليست بالتجربة البسيطة ولكنها تجربة صعبة تحتاج الكثير من الجهد والوقت والتشجيع وإقناع الآخرين بجدوى وفائدة الكتابية باللغة العربية في المجالات العلمية . ومن هنا أوجه نداء إلى كل الزملاء أعضله هيئات التدريس في الجامعات المصرية والعربية ، إذا كان كل منال يفهم في تخصصه ويجيده فماذا يمنعه من كتابة أفكاره بلغته الأم ؟ والله إن الفائدة لعظيمة من وراء أن يجد الطالب مرجعا باللغة العربية يتساوى مع أكبر المراجع الأجنبية في الموضوع ، وإن ذلك من واقع تجربتي الشخصية في هذا المجال على مدى خمس سنوات على الأقل .

المؤلف

# الفصل الأول

פמן ואיבלפון פועפון פאר ואיבלפון פאר ואיבלפון פאר Century of Microprocessor

# 1-1 عصر الميكروبروسيسور Century Of Microprocessor

لقد كان التقدم النشط في علوم الإلكترونيات والسرعة الهائلة التي يمكن أن تنفذ بها العمليات الحسابية والتعقيد الذي وصلت إليه عملية بناء الشرائح الإلكترونية (الدوائر التكاملية) الأثر الكبير في جميع نواحي الحياة وعلى الكثير من العلوم المختلفة . كما أن الطفرة الأخيرة التي حدثت في علوم الحاسبات يرجع الفضــل فيها أساسا إلى التقدم في علوم الإلكترونيات والتكنولوجيا الحديثة والمتطورة في تصنيع الدوائر التكاملية Integrated circuits ، فما هي الدائرة التكاملية إذن؟ لكي نعرف ما هي الدائرة التكاملية تعال نرجع إلى الوراء في التاريخ وبالتحديد فـــى بداية الخمسينات عندما تم اكتشاف الترانزيستور . في هذا الوقت كانت الدوائــر الإلكترونية تبنى أو تصمم باستخدام الصمامات المفرغة التي كان منها ما يكافئ التر انزيستور ومنها ما يكافئ الدايود على سبيل المثال وكان أي صمام من هـــذه الصمامات عبارة عن اسطوانة زجاجية مفرغة من الهواء يبلغ قطر هـا حوالي ثلاثة سنتمترات وارتفاعها حوالى سبعة سنتمترات وكانت هذه الصمامات تحتاج لتشغيلها إلى فرق جهد مستمر d.c عالى يبلغ فوق 200 فولت ، ولذلك كانت هذه الصمامات تشع الكثير من الحرارة مما كان يتطلب الكثير من وسائل التبريد لها. لذلك كانت جميع الأجهزة الإلكترونية في هذا الوقت تعرف بكبر حجمها ، فلك أن تتخيل مثلا أن جهاز حاسب شخصى من أبسط الأجهزة المعروفة الآن ربما كان يشغل حجرتين كاملتين متوسطتي الحجم لو أنه بني بهذه الصمامات .

باكتشاف أشباه الموصلات وظهور الترانزيستور أخذت أحجام الدوائر الإلكترونية والفراغ الذى تشغله فى الانكماش ، ومنذ ذلك الحين بدأت عجلة التطور فى بناء الدوائر الإلكترونية فى الدوران وأصبح المصممون لا يكتفون ببناء ترانزستور واحد على نفس شريحة شبه الموصل ولكن بدءوا فى وضع أكثر من ترانزيستور على نفس القطعة ، ثم أضافوا لهذا العدد من الترانزستورات بعصض المكونات معى الأخرى مثل المقاومات والمكتفات ، ثم قاموا بتوصيل هذه المكونات مع الترانزستورات الموجودة على نفس الشريحة للحصول على دائرة إلكترونية تؤدى وظيفة معينة ، هذه الدائرة الإلكترونية المبنية على شريحة واحدة لأداء هدف أو وظيفة معينة هى ما يسمى بالدائرة التكاملية . فى بداية الستينات كان كل ما تمكنت منه التكنولوجيا فى ذلك الوقت هو بناء أو تجميع حوالى عشرة ترانزستورات على نفس الشريحة واستخدمت هذه في بناء دوائر البوابات المنطقية مثل بوابة AND وبوابة OR وبوابة NOT وغيرها وسميت هذه الدوائر التكامل الصغير (Small Scale Integration (SSI) .

بعد ذلك أخذت تكنولوجيا بناء الدوائر التكاملية في التطور السريع حيث تمكن المصممون من زيادة كثافة المكونات على نفس الشريحة فظهرت الدوائــر ذات التكامل المتوسط (Medium Scale Integration (MSI) والتي منها علي سبيل المثال دوائر العدادات counters ومسجلات الإزاحة shift registers والكثير من المكبرات التماثلية analog amplifiers المتعددة الأغراض ، ولم يقف الأمر عند هذا الحد بل ظهرت بعد ذلك الدوائر عالية التكامل Large Scale Integration (LSI) والتي منها شرائح الذاكرة memory وشرائح المعالجات بجيليها الأول والثاني ، ولم يقف الأمر عند هذا الحد أيضا بل ظهرت بعد ذلك الدوائر التكاملية الفائقة التكامل (Very Large Scale Integration (VLSI) والتي منها بعض شر ائح الذاكرة والأجيال الأخيرة من شرائح المعالجات والتي منها الجيل الثالث والرابع، ولك أن تتخيل الآن أن عدد الترانزستورات على الشريحة الواحدة التي لا تتعدى مساحتها السنتمتر المربع الواحد قد فإق عدة ملايين من الترانزستورات على نفس الشريحة ، فالمعالج بنتيم برو (آخر أجيال المعالجات هذه الأيسام) Pentium Pro يحتوى على 5.5 مليون تر انزستور . ويعلم الله وحده ما سيأتي لنا به المستقبل القريب وإلى أين سيصل هذا العقل البشرى ؟ هذه النعمة التسى دائما يحاول الإنسان تقليدها ولكنه دائما سيخفق في تصنيعها!!

لقد كان ظهور المعالج هو السبب في الطفرة الأخيرة التي ظهور في علوم الحاسبات والتي تركت آثارها بالتالي على جميع العلوم الأخرى بل وأوجدت أو أحيت علوما كانت على وشك النسيان بسبب المقدرة المحدودة على معالجة وتخزين البيانات في تلك الأوقات ، فمن كان يتخيل مثلا أن عملية التحكم في أنظمة الطاقة الكهربية ابتداء من توليدها وانتهاء بتوزيعها على المشتركين مسن الممكن أن يلعب الحاسب دورا كبيرا فيها ، جميع المصانع الأن لا تخلـــو مـن كومبيوتر يتحكم في أعقد العمليات الصناعية فيها ، بل إننا إذا انتقلنا إلى المجال الطبى ودخلنا حجرة العمليات لوجدنا الغالبية العظمي من أجهزتها الآن تستخدم الحاسب . إن الحاسب الآن دخل جميع نواحي الحياة فمن كان يتخيل أن يستخدم المعالج في التحكم في خلط الهواء بالبنزين بل ومراقبة الكثير من أداء السيارة وأجزائها . إنك من الممكن أن تشترى لعبة لطفلك الآن ليلعب بها فتفاجا بأن بداخلها معالج يتحكم فيها . إن علم الذكاء الصناعي Artificial intelligence من كثير من العلوم التي ما كانت ستصل إلى ما وصلت إليه الآن لــولا ظــهور المعالج . لذلك فإنني أرى أن يسمى هذا العصر فعلا بعصر (الميكروبروسيسور) المعالجات أسوة بعصر البخار وعصر الكهرباء التي مرت بها البشرية سابقا . إن نظرة مبسطة على شريحة المعالج ستجد أنها كباقي الشرائح بــل والأجهزة الإلكترونية ، لكي تتمكن من استخدامها لابد من قراءة الكتالوج الخاص بها ، والكتالوج الخاص بشرائح المعالج يحتوى عادة على جزأين: الجزع الأول يكون خاصا بالتركيب الوظيفي لجميع أجزاء الشريحة ووظيفة جميع أطرافها وشكل الإشارة الناتجة أو المطلوبة على كل طرف من هذه الأطراف. الجيزع الثياني يحتوى مجموعة أوامر الشريحة والتي بها يمكنك برمجتها وعدد هدذه الأوامر يختلف بالطبع من شريحة لأخرى وكذلك صيعة الأوامر تختلف باختلاف الشريحة. لذلك سنحاول من خلال فصول هذا الكتاب أن نقوم بتغطية هذيت الجزأين بالإضافة إلى كيفية مواجهة أو توصيل شريحة المعالج على الأجهزة أو الشرائح الخارجية للحصول على نظام الميكروكومبيوتر ذى الكارت الواحد One board microcomputer الذي يستخدم في الكثير من أغراض التحكم وفي الكثــير من التطبيقات العملية ، كل ذلك من خلال دراسة مفصلة ومتأنية للمعالجات ذات 8 بت والمعالجات ذات 16. بعد ذلك سيكون هناك عرضا سريعا للمعالجات 32بت والأجيال الأخيرة منها ودراسة الفرق بينها وبين الأجيال السابقة . قبل أن نترك المقدمة ومحاولة لإتمام النظرة العامة على الموضوع سنعرض في الجرزء القادم لتركيب الميكروكومبيوتر وما يمثله المعالج بداخله .

# ? أين يقع المعالج فى داخل الميكروكومبيوتر -1 (Computer Architecture)

إن الفكرة التى يقوم عليها الحاسب ما هى إلا تقليدا لطريقة الإنسان فى حـل أى مسألة . أنت مثلا حينما تريد أن تحل مسألة فى الطبيعة أو الإلكترونيات ، ماذا تحتاج ؟ إنك لكى تحل هذه المسألة ستحتاج للآتى :

1. القوانين المهمة لحل هذه المسألة وبالطبع فإنك ستستعين بأحد الكتبب التبي تحتوى على هذه القوانين .

2. ستحتاج كراسة أو بعض الأوراق لتدوين بعض النتائج الحسابية .

3. ستحتاج أيضا إلى آلة حاسبة لمساعدتك في إجراء بعض العمليات الحسابية .

 4. أخيرا ربما تحتاج إلى آلة طابعة لكتابة تقرير أو وضع الحل فى صورة نهائية لائقة .

هذه الأشياء الأربعة لو تم توفيرها مجتمعة لن تحل المسألة من تلقاء نفسها ولكن لابد من وجود منظم لعملية الحل وهو الشخص نفسه ولابد من وجود خطة للحل أيضا . هذه الأجزاء الأربعة السابقة هي تقريبا ما يتركب منه الحاسب كما سنرى سوى أن خطة الحل وهي البرنامج يتم وضعها للحاسب عن طريق الإنسان بحيث إذا جاء الحل خطأ فلابد أن هناك خطأ في البرنامج الموضوع للحاسب

بواسطة الشخص المبرمج . أى أن الحاسب لا يحل المسألة من تلقاء نفسه ولكنه يسير على خطة الحل التى وضعتها أنت له مستقيدا فقط بالسرعة الهائلة التى ينفذ بها العمليات . لذلك سنعرض الآن للأجزاء الرئيسية فى الحاسب تاركين للقارئ أمر مقارنة هذه الأجزاء بالأجزاء الأربعة التى ذكرناها سابقا . يتكون الميكروكومبيوتر كما هو موضح فى شكل (1-1) من ثلاثة أجزاء رئيسية هى :

- ا. الذاكرة Memory.
- 2. وحدات الإدخال والإخراج Input/Output Ports.
- 3. وحدة المعالجة المركزية Central Processing Unit.

#### 1-2-1 الذاكرة Memory

الذاكرة ما هي إلا وعاء لحفظ المعلومات لحين الحاجة إليها وهذه المعلومات إما أن تكون بيانات ستكون هناك حاجة إليها فيما بعد أو تكون برنامجا مخزنا فللذاكرة في انتظار التنفيذ . إن أي برنامج تكتبه على الحاسب وبأي لغة ولتكلن لغة الباسيك BASIC مثلا لابد وأن يوضع أو لا في الذاكرة الأساسية للحاسب ثم يتم استدعاؤه من هناك للتنفيذ عند الأمر بذلك ، أي أن الحاسب لا ينفذ إلا برامج موجودة في الذاكرة الأساسية فقط . تنقسم الذاكرة عامة إلى قسمين :

القسم الأول و هو الذاكرة الأساسية للحاسب Main memory وهي التي تخزن فيها البرامج التي تتنظر التنفيذ ، و هذا النوع من الذاكرة يكون عادة من أشباه الموصلات Semiconductors و على شرائح تكاملية و يحدد مقدار ها على حسب نوع المعالج المستخدم في الحاسب كما سنرى فيما بعد . الذاكرة الأساسية للحاسب تنقسم بدور ها إلى جزأين :

الأول: وهو ما يسمى بذاكرة القراءة فقط Read Only Memory, ROM وهدذه الذاكرة أيضا تكون عبارة عن شرائح من أشباه الموصلات التسى تسم تسجيل محتوياتها بواسطة الصانع نفسه وعادة تحتوى الثوابت والبرامج المهمة انشغيل نظام الحاسب والتي لا تضيع بانقطاع مصدر الطاقة عنها.

الثانى: وهو ذاكرة القراءة والكتابة Read/Write Memory ولقد تم العرف على تسمية هذا النوع من الذاكرة بذاكرة الاتصال العشوائي Random Access تسمية هذا النوع من الذاكرة التي تحتوى البيانات والبرامج التي في انتظار التنفيذ كما ذكرنا من قبل وهذه الذاكرة تفقد محتوياتها بانقطاع مصدر الطاقة.

القسم الثاني من أقسام الذاكرة هو الذاكرة الإضافية أو Mass Memory وهي الذاكرة التي تستخدم لتخزين البيانات أو البرامج لفترات طويلة وعادة فإن هذه الذاكرة تكون مغناطيسية مثل الأقراص Floppy disks والشرائط Tapes وهناك

أيضا الأقراص الصلبة Hard Disks . هذا القسم من الذاكرة لا دخل للمعالج في تحديد كميته ولكن كميته تحدد على حسب رغبة المستخدم ومسا وصلت إليه التكنولوجيا في هذا المجال . شكل (2-1) يبين رسما توضيحيا لأقسام الذاكرة في الحاسب التي سبق الحديث عنها .





#### 1-2-2 وحدات الادخال والاخراج Input/output Ports

وحدات الإدخال هى الوسائل التى يتم بها تكييف المعلومات لتكون فى صورة مناسبة يستطيع البروسيسور التعامل معها ، ومثال ذلك لوحة المفاتيح التى تحول أى زرار تقوم بضغطه إلى إشارات كهربية وشفرات يقبلها المعالج . يجبب أن نفرق هنا بين بوابة الإدخال ووحدة الإدخال حيث بوابة الإدخال يتم من خلالها

إدخال المعلومات التي تم تجهيزها بواسطة وحدة الإدخال إلى المعالج كما سنرى بالتفصيل في فصول الكتاب القادمة .

وأما وحدات الإخراج فهى الوسائل التى يتم بها إظهار المعلومات الخارجة من المعلوم ، ومثال ذلك الشاشة التى ما هى إلا وسيلة ضوئية لإظهار المعلومات التى تخرج من المعالج ، بالطبع فإن هذه الشاشة تكون متصلة بأحد بوابات الإخراج ، ولذلك يجب أن نفرق هنا بين بوابات الإخراج ووحدات الإخراج حيث بوابة الإخراج يتم من خلالها إخراج المعلومة من البروسيسور إلى وحدة الإخراج التى تتعامل مع هذه المعلومات بوسائل مختلفة كما سنرى بالتفصيل .

#### 1-2-1 وحدة المعالجة المركزية

Central Processing Unit, cpu

الوظيفة الأساسية لوحدة المعالجة المركزية هي تنفيذ البرامج عن طريق إحضار الأوامر من الذاكرة الواحد بعد الآخر ثم تنفيذها بنفس النتابع ، فمثلا يتم إحضار الأمر الأول ثم ينفذ وبعد ذلك يحضر الأمر الثاني وينفذ فالأمر الثاني وينفذ فالأمر الثانت مين وهكذا إلى أن تصل إلى نهاية البرنامج . بعض هذه الأوامر تحتاج لبيانات مين أماكن أخرى في الذاكرة يتم إحضارها ، وبعضها يحتاج لبيانات مين بوابات إدخال يتم إحضارها أيضا ، والبعض الآخر من الأوامر يتطلب كتابة أو تسجيل بعض البيانات إما في الذاكرة أو في وحدات إخراج ، كل ذلك وأكثر تقوم به وحدة المعالجة المركزية ، في معظم أنظمة الميكر وكومبيوتر الشخصية تكور وحدة المعالجة المركزية هي شريحة أو أكثر من شرائح الميكروبروسيسور أو المعالج الدقيق كما سمى بالعربية والذي هو موضوع دراسة هذا الكتاب .

## 1-3 ماذا تعنى هذه الألفاظ؟

نسمع هذه الأيام الكثير من الألفاظ والتى لا نعرف مدلولها الدقيق ولا ماذا تعنى هذه الألفاظ ؟ لذلك سنقدم فى هذا الجزء بعض هذه الألفاظ مسع شسرح بسيط لمدلولها والاستعانة ببعض الأمثلة إن أمكن .

# 1-3-1 الميكروكومبيوتر والميكروبروسيسور

لقد رأينا في هذا الفصل كيف أن كلمة ميكروبروسيسور تعنى تلك الشويحة ذات الأطراف المتعددة والقادرة على تنفيذ مجموعة من الأوامر المحددة بحيث ينفذ كل أمر عند إعطاء الشفرة الخاصة به . كلما تعددت هذه الأوامر ، وكلما كان المعالج أسهل في عمليات المعالج أسهل في عمليات

المواجهة مع الدوائر المحيطة كلما كان المعالج أفضل . في الكثير من الأحيان يستخدم لفظ "بروسيسور" فقط للدلالة على نفس الشيء ، ونحن في هذا الكتاب سنستخدم أي واحد من اللفظين "بروسيسور" أو "ميكروبروسيسور" أو المرادف العربي لهما وهي كلمة "المعالج" نظرا لشيوع استخدام كل هذه الألفاظ .

أما الميكروكومبيوتر فقد رأينا سابقا أنه ذلك الجهاز الذي يتكسون من بعسض الأجزاء الثانوية مثل الذاكرة ووحدات الإدخال والإخراج وجزء أساسسي وهو المعالج . أي أن المعالج يعتبر جزءا أساسيا بل هو أهم جزء في الميكر وكومبيوتر . عند ذكر كلمة ميكر وكومبيوتر يتبادر إلى ذهننا فروا تلك المجموعة المكونة من شاشة للعرض ولوحة مفاتيح وطابعة وغيير ذلك من الأجهزة ، ولكن في الحقيقة فإن هذا هو أحد أشكال الميكروكومبيوتر موضوعا في صورة تسهل عملية التعامل معه وبرمجته حتى من غير المختصيب الذيب يتعاملون معه بغرض البرمجة فقط باستخدام اللغات المعروفة . هنساك صورا أخرى للميكروكومبيوتر غير هذه الصورة المألوفة مثــل "الميكروكومبيوتــر ذو الكارت الواحد" مثلا وهو عبارة عن كارت واحد عليه شريحة المعالج وشريحة ذاكرة والقلبل من بوابات الإدخال والإخراج ، كل ذلك مبنى على كارت واحد لأداء غرض معين مثل التحكم في أي عملية صناعية كما سنرى في هذا الكتاب. بل إن هناك صورة أخرى للميكر وكومبيوتر وهي الميكر وكومبيوتر على شريحة واحدة ، نعم شريحة واحدة تحتوى معالج وبعض الذاكرة (RAM و ROM) وبعض بوابات الإدخال والإخراج . بل إن هناك بعض شرائح الميكر وكومبيوتو التي تحتوى الأكثر من ذلك مثل المحولات مسن تماثلي السي رقمسي (A/D) والمحولات من رقمي إلى تماثلي (D/A) والمؤقتات (Timers) والمرشحات الرقمية ( Digital Filters) وغير ذلك وعادة ما يطلق على هذه الشرائح الحاكمات الدقيقة Microcontrollers

#### Software and Hardware البرمجة والبناء

يكون التعامل مع المعالج في العادة بوسيلة من اثنتين لا غنى لواحدة منهما عن الأخرى:

الوسيلة الأولى: هي برمجة المعالج وهو ما يسمى software وعادة ما تكون البرمجة بلغة الماكينة الخاصة بالبروسيسور الذي تتعامل معه حيث أن كل بروسيسور له لغة ماكينة خاصة به كما سنرى في هذا الكتاب.

الوسيلة الثانية: هي البناء hardware وتشتمل على مواجهة أو توصيل البروسيسور على الدوائر المحيطة مثل الذاكرة وبوابات الإدخال والإخراج واستخدام البروسيسور في التطبيقات المختلفة مثل دوائر التحكم مثلا البرمجة المتعامل مع المعالج لابد وأن يكون ملما بكلتا الوسيلتين السابقتين ، البرمجة

والبناء ، وإن اختلفت نسبة إلمامه بأى واحدة منهما ، فإنه من الصعب لشخص ما أن يتعامل مع البروسيسور بغرض البرمجة فقط لأن ذلك سيعتبر إهدارا لوقت حيث إنه إذا كان يريد غرض البرمجة فقط فيمكنه استخدام أى واحدة من اللغات المعروفة والتي يكون تعلمها أسهل بكثير من تعلم برمجة البروسيسور بلغة الماكينة أو الأسميلي . أى أن من يتعامل مع البروسيسور فإنه غالبا يتعامل معه بغرض استخدامه كعنصر فعال في دائرة تحكم لمميزاته المختلفة ، لذلك لابد لهذا الشخص أن يتعلم برمجة البروسيسور ومواجهته واستخدامه في الأغراض المختلفة . وعادة تطلق كلمة Software على البرمجة بأى لغة من اللغات وأمل كلمة Hardware فتطلق على عمليات البناء والتركيب الإلكتروني بأى شكل و لأى غرض .

#### 1-3-3 الأمر والبرنامج Instruction and Program

أعطني القلم!! هذا أمر Instruction .... وأما

- 1. خذ المفتاح
- 2. افتح درج المكتب
  - 3. خذ القلم
- 4. اكتب "أنا أتعلم البرمجة"
  - 5. أعد القلم
  - 6. أغلق الدرج
  - 7. أعطني المقتاح

فهذا برنامج مكون من سبعة أوامر .

أى أن الأمر هو وحدة بناء البرنامج ، بينما البرنامج يتكون من مجموعة من الأوامر التي لو تم تتفيذها بالتتابع المحدد فإنها تؤدى هدف أو وظيفة معينة . أى برنامج لابد وأن ينفذ بالتتابع الذي كتب به وهذا هو ما يفعله المعالج بحيث إذا وجد هناك خطأ ما في النتيجة فإن ذلك يرجع إلى البرنامج وليس إلى المعالج لأن المعالج ما هو إلا ماكينة مطيعة تتفذ ما يطلب منها حتى ولو كان خطأ طالما أن ذلك في حدود إمكانياتها .

### Programming Languages لغات البرمجة 4-3-1

تخيل أن لدينا ماكينة وهذه الماكينة لها 3 مفاتيح تشغيل ، كل مفتاح يكون إما ON أو OFF ، وعلى ضوء حالة المفاتيح الثلاثة يمكن لهذه الماكينة أن تنفذ عملية معينة . جدول 1-1 يبين جميع الحالات الممكنة المفاتيح الثلاثة والعملية المقابلة لكل حالة . هذه العمليات التى تستطيع الماكينة تنفيذها هي مجموعة

الأوامر الخاصة بهذه الماكينة وعلى ضوء هذه العمليات وبالاستعانة بالجدول 1
1 فإننا نستطيع إعادة كتابة البرنامج الموجود في الجزء السابق في صورة شفرات تستطيع هذه الماكينة تتفيذها ، جدول 1-2 يبين هذا البرنامج وقد أعيدت كتابته وفي مقابل كل أمر الشفرة الخاصة به مجموعة الأوامر المكتوبة بالوحايد والأصفار في جدول 1-2 هي البرنامج مكتوبا بلغة الماكينة لهذه الأله التي نستخدمها . لذلك فإنه عامة وكما سنرى في هذا الكتاب فإن لغة الماكينة الماكينة وحون عبارة عن شفرات ثنائية (وحايد وأصفار) تدخل إلى البروسيسور فينفذها وهي الصورة الوحيدة التي يمكن التعامل بها مع أي بروسيسور ، وكما سنرى أيضا فإن لكل معالج لغة الماكينة الخاصة به .

| S2 | S1 | S0 | العملية المنفذة                       |
|----|----|----|---------------------------------------|
| 0  | 0  | 0  | خذ (یاخذ أی شیء یعطی له فی یده)       |
| 0  | 0  | 1  | افتح (یستخدم ما معه لفتح ما یحدد له)  |
| 0  | 1  | 0  | أكتب (يستخدم ما معه للكتابة)          |
| 0  | 1  | 1  | ضع (ضع ما معك في المكان المحدد)       |
| 1  | 0  | 0  | أغلق (يغلق ما يحدد له)                |
| 1  | 0  | 1  | أعطني (يعطى ما معه)                   |
| 1  | 1  | 0  | اذهب (بذهب إلى مكان محدد )            |
| 1  | 1  | 1  | تكرار (يكرر ما يحدد له عدد من المرات) |

جدول 1-1 مجموعة أوامر ماكينة افتراضية

مما سبق يتضح لنا أن الكتابة بلغة الماكينة ليست سهلة وأصعب منها اكتشاف الأخطاء فيها ، لذلك فإنه يمكن الكتابة بالأوامر خذ وافتح واكتب وهكذا ولكن في هذه الحالة بدلا من إدخال الأوامر على الماكينة مباشرة فإننا ندخلها على مسترجم يقوم بترجمة الكلمات خذ واكتب إلى شفراتها الثنائية ثم يدخلها على الماكينة. هذا المترجم يسمى أسمبلر والأوامر المكتوبة بلغة أكتب وخد سنسميها لغة الأسمبلي . هذا هو الوضع تماما في حالة المعالج حيث أن كل بروسيسور له لغة ماكينة وأسمبلر ولغة أسمبلي خاصة به . اذلك فإن لغة الأسمبلي هدى أقرب اللغات من مستوى لغة الماكينة . الآن ما رأيك لو استطعنا تصميم مترجم آخر بالغات من مستوى لغة الماكينة . الآن ما رأيك لو استطعنا تصميم مترجم آخر بيرجمة ذلك الأمر إلى عدد من أوامر لغة الماكينة وليس إلى أمر واحد كما في حالة الأسمبلر ، مثل هذه اللغة التي يكون كل أمر فيها يؤدى وظيفة أكثر من أمر من أوامر لغة الأسمبلر ، مثل هذه اللغة التي يكون كل أمر فيها يؤدى وظيفة أكثر من أمر من أوامر لغة الأسمبلى العالية الأسمبلى توى العالي High level

language ومنها على سبيل المثال لا الحصر لغة الباسيك والفورتران والبسكال وغيرها كثير . إن المترجم الذى يقوم بالترجمة من لغة ذات مستوى عال السلم لغة ماكينة يسمى المؤلف أو المفسر أو المترجم أو compiler .

| S2 | S1 | S0 | حالة المفاتيح | الأمــــــــــــــــــــــــــــــــــــ |
|----|----|----|---------------|------------------------------------------|
| 0  | 0  | 0  |               | خذ (المفتاح)                             |
| 0  | 0  | 1  |               | افتح (درج المكتب)                        |
| 0  | 0  | 0  |               | خذ (القلم)                               |
| 0  | 1  | 0  |               | اكتب (أنا أتعلم البرمجة)                 |
| 0  | 1  | 1  |               | ضع (القلم)                               |
| 1  | 0  | 0  |               | أغلق (الدرج)                             |
| 1  | 0  | 1  |               | أعطني (المفتاح)                          |

جدول 1-2 برنامج مكتوب بلغة الماكينة الافتراضية

#### bit والبايت bit والبايت byte

البت هي الخانة في نظام العد الثنائي ، فكما أن العدد العشرى 325 مثلا مكسون من ثلاث خانات فإن العدد الثنائي 11001 مكون من خمس خانسات أو خمسس بناث خانات فإن العدد الثنائي 11001 مكون من خمس خانسات أو خمسس بناث 5 bits حيث كل خانة تحتوى على واحد أو صغر . عمليا وكما نعلسم مسن الإلكترونيات الرقمية فإن البت تكون عبارة عن قلاب flip flop أو أحيانا تسسمي ماسك اعدا يتم وضع خرجه على القيمة واحد أو صغر . كل ثمانية بنات تكون فيما بينها ما يسمى بالبايت byte ، والبايت هي وحدة تقدير الذاكرة فنقول مثلا أن فيما بينها ما يسمى بالبايت عقدارها 64 كيلو بايت أي 65536 بسايت حيث أن الواحد كيلو بايت يساوى 1024 بايت كما سنعرف بالتفصيل فيما بعد . شكل (1- الواحد كيلو بايت يساوى 1024 بايت كما سنعرف بالتفصيل فيما بعد . شكل (3- وعلى ذلك فإن الكلمة word تتكون من 16 بت أو اثنين بايت كما هو موضح في وعلى ذلك فإن الكلمة word .

### 4-1 تـــمـــاريـــن

1. وضح بالرسم الصندوقي أجزاء الميكروكومبيوتر واشرح باختصار وظيفة كل جزء ؟



- 2. طابق بين الأجزاء التي شرحتها في السؤال السابق وما تحتاج إليه من أشياء لحل مسألة في الرياضيات مثلا كما هو موضح في الفصل ؟
  - اشرح أنواع الذاكرة وخصائص كل نوع ؟
  - 4. دليل التليفون ، هل تطابقه مع RAM أم ROM ؟
  - 5. شريط الكاسيت ، هل تطابقه مع RAM أم ROM ؟
- - 7. الفأرة mouse ، هل هي وحدة إدخال أم وحدة إخراج ؟
    - 8. الطابعة ، هل هي وحدة إدخال أم وحدة إخراج ؟
  - 9. المساح scanner ، هل هو وحدة إدخال أم وحدة إخراج ؟
    - 10. الراسم plotter ، هل هو وحدة إدخال أم وحدة إخراج ؟
- 11. بافتراض أن لك تعاملات مسبقة مع الحاسب الآلى ، فما نوع المعالج الموجود
   في الحاسب الذي تتعامل معه ؟
  - 12. ما هو الفرق بين المعالج والميكروكومبيوتر ؟
  - 13. إذا شبهنا الميكروكومبيوتر بالسيارة ، فماذا يمثل المعالج في هذه السيارة ؟
- 14. ارسم مخطط سير flow chart لنشاطك اليومى من الصباح حتى النوم في أيام العمل وأيام العطلات ؟

# الفصل الثاني

البناء المعماري للمعالج Microprocessor Architecture

#### 1-2 مــقدمـــة

في هذا الفصل سيتم عرض المهام الأساسية المطلوبة من أى معالج بصفة عامة وعلى ضوء هذه المهام سنعرض الوظائف الأساسية للمكونات العامة لأى شريحة معالج ، ثم نقدم التركيب التفصيلي لاتنين من الشرائح المعروفة وهي الشريحة 1ntel8085 والشريحة 280 على أساس أن هذه هي أكثر شرائح الجيال الثاني استخداما وبعد ذلك سنترك القارئ رؤية مدى ملائمة هذا التركيب للمهام المطروحة . وسوف نعرض التركيب التفصيلي ليهذين المعاجين بصورة مختصرة وسريعة حتى يتمكن أى قارئ من مراجعة المكونات الأساسية لهما حتى ولو كان لا ينوى التدريب إلا على أحدهما . لذلك فإننا ننصح بقراءة هذا الفصل بأكمله من مستخدمي هذين المعالجين بالذات أو المعالجات التسي نقوم بعرضها في هذا الكتاب . ولقد رأينا في الفصل السابق (عصر المعالجات) أن وظيفة المعالج الأساسية هي إحضار الأوامر من الذاكرة وتتفيذها الواحد بعد وظيفة المعالج الأساسية هي إحضار الأوامر من الذاكرة وتتفيذها الواحد بعد

# 2-2 المهام الأساسية المطلوبة من المعالج

- ١٠ يجب أن يكون المعالج قادرا على إحضار معلومات من الذاكرة (هذه المعلومات قد تكون الأوامر أو قد تكون الأوامر نفسها).
- 2. يجب أن يحتوى المعالج على مكان مناسب بداخله لحفظ هذه المعلومات التى أحضرها لحين الحاجة إليها أو تتفيذها إذا كانت من الأوامر.
- 3. لابد أن يكون هناك أكثر من مكان بداخله بحيث يمكن نقل المعلومات فيما بين هذه الأماكن حيث تحتاج بعض الأوامر لذلك عند تنفيذها.
- 4. يجب أن تكون لديه الوسائل المناسبة لإدخال معلومات من بوابات إدخال حتى يتسنى لنا قراءة لوحة مفاتيح أو إدخال درجة حرارة مثلا تمهيدا لمعالجتها رقميا .
- 5. يجب أن تكون لديه المقدرة على إجراء بعض العمليات الحسابية والمنطقية على البيانات التى أحضرها . العمليات الحسابية الأساسية هى الجمع والطرح والعمليات المنطقية الأساسية مثل AND و OR .
- المقدرة على إرسال بيانات إلى الذاكرة وتسجيلها فيها من المهام الأساسية للمعالج.

7. المقدرة على إرسال بيانات إلى وحدات إخراج من خلال بوابات إخراج حتى يتسنى لنا قراءة هذه المعلومات على شاشة أو إخراج بيانات نتحكم بها فى سرعة موتور مثلا.

كانت هذه هى المهام الأساسية للمعالج والتى يجب أن يحققها تركيب الداخلى ومجموعة أوامره كما سنرى . سنبدأ فيما يلى الحديث عن مجموعة المسجلات والعدادات التى يشتمل عليها أى معالج حيث أنه من الضرورى لأى مستخدم للمعالج أن يعرف خصائص تلك المسجلات ووظائفها .

# 2-3 أجزاء المعالج الأساسية

جميع شرائح المعالجات تتركب من ثلاثة أجزاء رئيسية وهى :

- 1. مجموعة مسجلات وعدادات.
- 2. وحدة الحساب والمنطق ALU .
  - 3. وحدة التزامن Clock .

بالنسبة لوحدة الحساب والمنطق سوف نرجئ الحديث عنها الآن حيث سيتم إفراد فصل قادم خاص بها (الفصل السادس) وأما وحدة التزامن فسوف يتم الحديث عنها أيضا لاحقا وفي معرض الكلام عن وظيفة كل طرف من أطراف شريحة المعالج . أما مجموعة المسجلات والعدادات ووظيفة كل منها فسوف تكون الموضوع الأساسي في الجزء القادم .

## 4-2 المسجلات والعدادات في شريحة المعالج

تستخدم المسجلات التخزين المؤقت المعلومات في صورة خانات ثنائية في داخل شريحة المعالج لحين الحاجة إليها . إن أي مسجل إزاحة يمكن تصميمه ليكون قادرا على أداء الوظائف التالية :

- 1. إدخال المعلومات بالتوالى وإخراجها بالتوالى (سواء من الشمال لليمين أو من اليمين الشمال) .
  - دوران المعلومات في أي اتجاه وعكسه.
  - 3. إدخال المعلومات بالتوازى وإخراجها بالتوازى .
  - لدخال المعلومات توالى من أى اتجاه وإخراجها توازي أو العكس.

المسجلات داخل المعالج يمكن النظر إليها على أنها و احد من نوعين ، الأول هو مسجلات عامة الأغراض general purpose registers و هذه تستخدم في الكثير من الأغراض وتؤدى أكثر من وظيفة وعادة تكون هدذه المسجلات متاحة

للمستخدم لكى يتعامل معها ، إما أن يسجل فيها أو يقرأ منها ، وأما النوع التانى فهو مسجلات خاصة الأغراض dedicated registers وهذه مسجلات موجودة لأداء غرض أو وظيفة واحدة لا تحيد عنها وليس للمستخدم أى وسيلة للتحكم فيها سواء بالقراءة منها أو الكتابة فيها .

أما العدادات counters فتستخدم عادة لعد النبضات الداخلة إليها ويمكن توظيف هذه العدادات لكى تقوم بعملية العد إما تصاعديا أو تنازليا مع ملاحظة أن خسرج العدادات يكون دائما توازي . سنعرض فيما يأتى بشكل عام لوظيفة كل مسجل من المسجلات الرئيسية الشريحة المعالج وذلك دون تخصيص معالج معين لأن ذلك مطبق على جميع المعالجات التي سنتعامل معها في هذا الكتاب .

#### Accumulator, A مسجل التراكم 1-4-2

أى مسجل يمكن النظر إليه على أنه بايت من بايتات الذاكرة وهده البايت موجودة داخل شريحة المعالج وعادة تكون هناك حرية أكثر في التعامل مع البيانات الموجودة داخل هذه المسجلات عن البيانات الموجودة في الذاكرة . من هذه المسجلات ما يسمى بمسجل التراكم Accumulator أو المركم . يعتبر مسجل التراكم ، وعادة يرمز له بالرمز A ، من أكثر مسجلات المعالج عملا ولذلك فإنه بمكننا النظر إليه على أنه سكرتيرا اشريحة المعالج . إن أي عملية حسابية أو أردت أن تجمع أي رقمين فإن واحدا منهما لابد وأن يوضع في مسجل التراكم وأما الرقم الآخر فيوضع في أي مسجل آخر أو حتى في الذاكرة ، ليس هذا فقط بل إن نتيجة أي عملية حسابية أو منطقية لا توضع إلا في مسجل التراكم ومنه يمكن نقلها لأى مكان آخر وذلك في المعالجات 8 بن . هناك مهمة أخرى أيضا لهذا المسجل وهي أن أي عملية إدخال أو إخراج من خلال بوابات الإدخـــال أو الإخراج عادة تكون من خلال هذا المسجل . أى أن المعلومة توضع في مسجل التراكم أو لا ثم يتم إخراجها إلى بوابة الإخراج ، أو إذا كانت المعلومة قادمة من بوابة إدخال فإنها توضع أو لا في مسجل التراكم ثم يتم نقلها منه لأى مكان آخر في داخل البروسيسور أو خارجه .

إذن ما رأيك الآن في تسميته بسكرتير المعالج ؟ إن عدد البتات (الخانات) bits (الخانات) data bus الموجودة في مسجل التراكم دائما يساوى عدد خطوط مسار البيانات التراكم واحد ومن الممكن في بعض المعالجات أن يكون هناك أكثر من مسجل تراكم واحد كما سنرى . بعض هذه الوظائف الخاصة بالمركم سيتم الاستغناء عنها في المعالجات 16 بت كما سنرى .

#### 2-4-2 عداد البرنامج Program Counter, PC عداد البرنامج

كما علمنا فإن مهمة المعالج الأساسية هي إحضار الأوامر من الذاكرة الواحد بعد الأخر ثم تتفيذها ، ولذلك فإنه لابد لهذه المهمة من تحديد للأماكن التي تحتــوي هذه الأوامر في الذاكرة . يحتوى عداد البرنامج دائما على عنوان المكان في الذاكرة الذي يحتوي الأمر الذي عليه الدور في التتفيذ ، وكلما تم إحضار أي أمر من الذاكرة وقبل أن يتم تتفيذه فإن عداد البرنامج تتغير محتوياته بحيث تشير إلى عنوان الأمر القادم في التنفيذ . تذكر أيضا أنه حتى لو حدث قفز من مكان في البرنامج إلى مكان آخر فإن وحدة التحكم داخل المعالج تضع عنوان الأمر الذي سيتم القَّفز إليه في عداد البرنامج حتى يصبح هو الأمر الذي عليه السدور في التنفيذ وتتتقل عملية تنفيذ البرنامج إلى هناك . عدد بتات هذا العداد دائما تساوى عدد بتات مسار العناوين address bus وهذا منطقى جدا حتى يتمكن المعالج من إحضار الأوامر مهما كانت في أي مكان في الذاكرة سواء في أولــها أو فـي آخرها ، لاحظ أن كمية الذاكرة التي يمكن أن يتعامل معها المعالج تتوقف على عدد البتات أو الخطوط في مسار العناوين كما سنرى فيما بعد . إذا نظرنا إلـــى عداد البرنامج على أنه مسجل يحتوى عنوان الأمر الذي عليه الدور في التنفيد فإننا سنصنفه على أنه من المسحلات ذات الأغراض الخاصة dedicated register ، لاحظ أيضا أنك كمبرمج لا تستطيع التحكم في محتويات هذا العداد .

## 2-4-2 مسجل وفاكك شفرة الأوامر

Instruction Register And Decoder

بعد أن يتم إحضار الأمر من الذاكرة إلى شريحة المعالج لابد وأن يسجل أو يوضع في أحد الأماكن في انتظار تنفيذه ، هذا المكان هو مسجل الأوامر يحتوى شفرة الأمر الذي يتم تنفيذه الآن . لاحظ أن عدد بتلت مسجل الأوامر عادة يساوى عدد بتات البايت في الذاكرة التي تساوى بدورها عدد بتات مسار البيانات خاصة في هذا الجيل من المعالجات الذي نحن بصدده الآن ، كما أن عدد الأوامر التي يمكن للمعالج أن ينفذها سيتوقف على عدد البتات في مسجل الأوامر فمثلا إذا كان عدد بتات مسجل الأوامر هو 8 بت فإن البتات في مسجل الأوامر فمثلا إذا كان عدد بتات مسجل الأوامر على الأكثر. فلك يعنى أن هذا المعالج يستطيع التعامل مع 256= (8) أمر على الأكثر. أول خطوات تنفيذ أي أمر تبدأ من فاكك شفرة الأوامر الذي يتصل دخله بخسر مسجل الأوامر كما في شكل (2-1) بحيث أنه على حسب شفرة الأمر الموجودة في مسجل الأوامر فإن عملية واحدة فقط سيتم تنفيذها على حسب الشفرة وحدة التحكم ووحدة الموجودة على دخل فاكك الشفرة ويتم ذلك بالطبع بمساعدة وحدة التحكم ووحدة الحساب والمنطق.

Status Register, SR مسجل الحالة 4-4-2

أحيانا يطلق على هذا المسجل اسم مسجل الأعلام Flag Register, FR . يعتبر هذا المسجل نشرة إخبارية تعكس حالة نتيجة آخر عملية حسابية أو منطقية قسام المعالج بتنفيذها ، فمن هذا المسجل نستطيع أن نعرف مثلا إذا كانت هذه النتيجة سالبة أم موجبة أم تساوى صفرا وغير ذلك من الأخبار المفيدة . هذا المسبجل يحتوى على عدد من البتات وكل واحدة منها تعتبر علما flag يعكس أو يدل على حالة معينة من العملية الحسابية أو المنطقية التي تم تنفيذها ، من هذه الأعلام ملالي يلى :

Zero flag, ZF علم الصغر Zero flag, ZF هذه البت تكون واحدا إذا كانت نتيجة آخر عملية حسابية أو منطقية تساوى صفرا وتكون هذه البت صفرا إذا كانت النتيجة مختلفة عن الصفر سواء موجبة أو سالبة .

<u>Sign flag. SF علم الإشارة Sign flag. SF</u> هذه البت تكون واحدا إذا كانت نتيجة آخر عملية حسابية أو منطقية نفذها المعالج سالبة ، أما إذا كانت هذه النتيجة موجبة فإن هذا العلم يكون صفرا ، لذلك فإنه أحيانا يسمى بعلم السالبية . Negative Flag, NF . Negative Flag, NF قدر بت تساوى صفرا فإن ذلك يعنى أن النتيجة موجبة أما إذا كانت هذه البيت واحدا فإن ذلك يعنى أن النتيجة سالبة لذلك فإنه دائما تكون محتويات علم الإشارة تساوى محتويات آخر بت فى النتيجة .



<u>Carry flag, CF</u> علم الحمل <u>Carry flag, CF</u> هذا العلم يكون واحدا إذا حصل حمل من آخر بت في أي عملية جمع أو حصل استلاف Borrow لآخر بـــت

في أي عملية طرح ويكون صفرا إذا لم يكن هناك حمل أو استلاف في أخر عملية حسابية . شكل (2-2) يبين كل من عمليات الحمل والاستلاف من والسي رقم 7 .

Parity flag, PF علم الباريتي Parity flag, PF هذا العلم يكون و احدا إذا كانت آخر عملية حسابية أو منطقية قام بها المعالج تحتوى على عدد زوجى من الوحايد فإن هذا العلم يكون أما إذا كانت هذه النتيجة تحتوى على عدد فردى من الوحايد فإن هذا العلم يكون صفرا.



واحدا إذا كان هناك حمل من الخانة أو البيني Half carry flag, HC واحدا إذا كان هناك حمل من الخانة أو البت الثالثة إلى البت الرابعة أي عملية جمع أو هناك استلاف من البت الرابعة إلى البت الثالثة نتيجة أي عملية طرح، ويكون صفرا فيما عدا ذلك أي إذا لم يحدث استلاف أو حمل من أو السي البت الرابعة ، لاحظ أننا هنا نبدأ عملية عد البتات بالرقم صفر، أي أن أول بت هي البت رقم صفر. شكل (2-3) يبين كيفية تأثر علم الحمل النصفي.

التطبيق على جميع هذه الأعلام واستخدامها سيأتى عند الشرح التفصيلي لأوامس المعالج ، مع العلم أن عدد الأعلام سيختلف من معالج لآخر كما سنرى عند دراستنا للتركيب التفصيلي لكل بروسيسور سندرسه في هذا الكتاب ولكن دعنا الأن ننظر المثال التالى كتطبيق سريع على هذه الأعلام .

## مثال 2- 1

اكتب محتويات الأعلام السابقة بعد إجراء عملية جمع الرقمين 77H و A5H . لاحظ أن الرقمين مكتوبين في الصورة الستعشرية hexadecimal .

الجمع الثنائي للرقمين السابقين سيتم كما يلي :

الرقم الأول 0111 0111 الرقم الأانى 1010 0101 النتحة 1000 1100 حمل 1

#### نلاحظ الأتى من النتيجة السابقة:

- 1. النتيجة لا تساوى الصفر ، إذن فعلم الصفر يساوى صفر 2F=0 .
- 2. آخر بت في النتيجة صفر فالنتيجة موجبة وعلم الإشارة يساوي صفر SF=0.
  - 3. هناك حمل من البت السابعة (الأخيرة) فعلم الحمل يساوى واحد CF=1.
  - 4. النتيجة تحتوى ثلاثة وحايد (عدد فردى) فعلم الباريتي يساوى صفر PF=0.
  - 5. ليس هناك حمل من الخانة الثالثة للرابعة فعلم الحمل النصفي يساوى صفر . HCF=0



## Stack Pointer register, SP مسجل مؤشر المكدسة 5-4-2

سيأتى إن شاء الله شرحا تفصيليا للمكدسة stack فيما بعد في معرض الكلام عن البرامج الفرعية وبرامج المقاطعة ، ولكن الآن بإمكانك أن تعرف أن المكدسة هي جزء من الذاكرة يتم فيه تخزين بعض العناوين أو البيانات المهمة والتي لابد من الحاجة إليها واسترجاعها مرة ثانية وبنفس الترتيب الذي تم تخزينها به مسجل مؤشر المكدسة يحتوى عنوان آخر مكان تم التسجيل فيه في هذا الجزء من الذاكرة ، لذلك فإنه طالما أن هذا المسجل سيحتوى على عنوان فلابد أن يكون 16 بت ، لاحظ أن المبرمج عادة تكون لديه الحرية في اختيار الجزء من الذاكرة الذي سيستعمل كمكدسة .

## 6-4-2 المسجلات عامة الأغراض General Purpose Registers

فى الكثير من الأحوال عندما نجمع أكثر، من رقم ، نحتاج لحفظ نتيجة معينة لحين استخدامها فى عملية أخرى لاحقة ، ولذلك فإنه بدلا من إرسال هذه النتيجة إلى الذاكرة ثم استدعائها ثانية مما يأخذ الكثير من الوقت فقد تم تجهيز المعالج ببعض المسجلات التى تستخدم لتخزين مثل هذه النتائج المرحلية لحين الحاجة إليها . عدد البتات فى هذه المسجلات يكون عادة مساويا لعدد بتات مسار البيانات . عدد هذه المسجلات يختلف من معالج لآخر ومن شركة لأخرى . ولقد

تم التعارف على تسمية هذه المسجلات بالمسجلات B و D و D و D و D و D كمسا سمى المركم من قبل بالمسجل D . هذه التسمية كما سنرى هي التسمية التسمى المركم مع لغة الأسمبلي (التجميع) assembly language . شكل (D يبين جميع المسجلات التي تكلمنا عنها حتى الآن والتي تمثل كما ذكرنا الحد الأدنسي لمحتويات أي معالج من المسجلات .



هناك بعض الأوامر التى تتعامل مع هذه المسجلات كأزواج يتكون كل زوج منها من 16 بت بدلا من التعامل معها كمسجلات يحتوى الواحد فيها علي 8 بتات فقط. فى هذه الحالة يكون كل مسجل له مسجل آخر يمكن ازدواجه معه ولا يمكن ازدواجه مع أى مسجل آخر ، فمثلا المسجل B لا يزدوج إلا مع المسجل C فقط وكذلك المسجل D لا يزدوج إلا مع المسجل E والمسجل D لا يزدوج إلا مع المسجل C وكذلك المسجل L . لاحظ أنه فى حالة ازدواج المسجل B والمسجل D فإن المسجل C يحتوى أو يمثل البايت ذات القيمة الصغرى low significant byte من المعلومة المكونة من 16 بت والمسجل B يحتوى البايت ذات القيمة العظمى HI المكونة من 16 بت والمسجل DE يحتوى البايت ذات القيمة المعلومة . بنفس الطريقة فى حالة الأزواج DE و DE

فإن المسجلات E و E تحتوى البايت ذات القيمة الصغرى والمسجلات E و E تحتوى البايت ذات القيمة العظمى . فمثلا إذا أردنا أن نسجل المعلومــة 4CF6H المكونة من 16 بت فى زوج المسجلات E فإن البايت E وهـــى البــايت ذات القيمة الصغرى لابد أن توضع فى المسجل E وأمـــا البــايت E ذات القيمــة العظمى فتوضع فى المسجل E . فى شكل (E ) ستلاحظ أن هــذه المسجلات موضوعة بنفس طريقة وكيفية ازدواجها .

إن التعامل مع هذه المسجلات من خلال المعالج يتم عن طريق شفرة أو كود code تم إعطاؤه لكل واحد من المسجلات العامة ولكل زوج منها بحيث يعرف كل مسجل في لغة الماكينة كما سنرى فيما بعد بهذه الشفرة أو هذا الكور . إن هذه الشفرة كما هو موضح في جدول 2-1 مكونة من وحايد وأصفار فقط وهذا يتناسب مع متطلبات لغة الماكينة . تذكر أيضا أن المكونات التي رأيناها إلى الآن ما هي إلا أقل ما يمكن أن يحتويه أى بروسيسور وإن اختلف عددها من بروسيسور لآخر كما سنرى .

| الشــــــــــــــــــــــــــــــــــــ | المسجل         |
|-----------------------------------------|----------------|
| Code_                                   | Register       |
| 111                                     | A              |
| 000                                     | В              |
| 001                                     | С              |
| 010                                     | D              |
| 011                                     | E              |
| 100                                     | H              |
| 101                                     | L              |
| 110                                     | M              |
| Register pairs                          | أزواج المسجلات |
| 00                                      | BC             |
| 01                                      | DE             |
| 10                                      | HL             |
| 11                                      | SP             |

جدول 2-1 المسجلات وأزواج المسجلات وشفراتها الثنائية

# 2-5 نظرة خارجية على شرائح المعالج

إن مجموعة شرائح المعالجات ذى 8 بتات التى ندرسها فى هذا الكتاب كلها لها عدد 40 طرفا تخرج منها ، وكذلك المعالج 8086 ذو 16 بت . ابتداء من المعالج 80186 بدأ عدد أطراف هذه المعالجات فى الزيادة حيث أصبح 68 طرفا فى

المعالج 80186 ، وظل فى الزيادة إلى أن وصل إلى 296 طرفا فى حالة المعللج بنتيم برو Pentium Pro وهو آخر المعالجات التى سندرسها فى هذا الكتاب . فملا هى وظيفة كل طرف من هذه الأطراف ، ولماذا كل هذا العدد من الأطراف ؟ إننا هنا سنحاول إلقاء نظرة سريعة على وظائف الأطراف الأساسية فقط وسوف نرجئ الحديث التفصيلي عنها وشكل الإشارات على كل طرف وكيفية ربط هذه الأطراف بالعالم المحيط بشريحة المعالج إلى فصول خاصة بذلك . هذه الأطراف يمكن تقسيمها إلى المجموعات التالية :

#### 1-5-2 مسار العناوين Address bus

أى مكان يريد المعالج أن يتعامل معه سواء كان ذاكرة أو غيرها لابد وأن يحدد المعالج عنوانا لهذا المكان . هذا العنوان يتم وضعه في صورة شفرات كهربيسة من الوحايد والأصفار بواسطة المعالج على عدد من هذه الأطراف الخارجة من المعالج تسمى مسار العناوين . لذلك فإنه على حسب عدد هذه الأطراف المخصصة لحمل شفرة العناوين يتحدد عدد الأماكن التي يمكن للبروسيسور أن المخصصة لحمل شفرة العناوين يتحدد عدد الأماكن التي يمكن للبروسيسور أن الخطوط أو الأطراف . في جميع الشرائح 8 بت والتي نحن بصدد الكلام عنها يكون عدد أطراف مسار العناوين يساوي 16طرفا لذلك فإن مقدار الذاكرة التي يتعامل معها مثل هذا البروسيسور يساوي 16طرفا لذلك فإن مقدار الذاكرة التي يتعامل معها مثل هذا البروسيسور يساوي 1024 بايت . لاحظ أن الإشارة الموجودة باعتبار أن كل واحد كيلو بايت يساوي 1024 بايت . لاحظ أن الإشارة الموجودة على مسار العناوين تكون دائما خارجة من البروسيسور إلى الأجهزة الخارجية وليس العكس لأن البروسيسور هو فقط الذي يحدد العنوان الذي يريد التعامل معه . جدول 2-2 يبين علاقة بين عدد خطوط مسار العناوين وكمية الذاكرة التي يمكن التعامل معها في كل حالة .

#### 2-5-2 مسار البياثات Data bus

بمجرد أن يحدد المعالج المكان الذي يريد التعامل معه عن طريق العنوان الدى وضعه على مسار العناوين يقوم المعالج بإخراج أو استقبال المعلومة نفسها على أو من مسار آخر وهو مسار البيانات. هذا المسار أيضا عبارة عن عدد من الخطوط تصل بين المعالج والأجهزة المحيطة حيست تسير عليها البيانات المطلوب تداولها بين المعالج والأجهزة خارجه. إن عدد البتات التي تعرف بها أي شريحة معالج يكون على حسب عدد بتات أو أطسراف مسار البيانات، فالشرائح 8 بت سميت كذلك لأن لها مسار بيانات مقداره 8 بت والشرائح 16 بتل سميت كذلك لأن لها مسار بيانات أو البتات وكل بت أو خانة مسار معلومة دائما في صورة عدد من الخانات أو البتات وكل بت أو خانة مسن هذه

الخانات يوضع بها واحد أو صفر حيث يمثل الواحد بجهد معين ويمثل الصفر بجهد آخر . التركيبة المكونة من هذه الوحايد والأصفار هي ما يسمى بالشــفرة الثنائية للمعلومة . إن ثمانية من هذه البتات أو الخانات تسمى بايت واثنين بايت تسمى كلمة أو Word . كمثال على هذه الشفرات الرقم 85H الذي شفرته هـــى 10000101 ، ولزيادة المعلومات عن نظم العد والتشفير المتبعة في الحاسب يمكن الرجوع إلى أي كتاب عن الإلكترونيات الرقمية . عندما يتعامل المعالج مع الذاكرة فإن وحدة التعامل بينهما تتوقف على عدد خطوط مسار البيانات لأن كلى بت من بتات المعلومة تنقل على خط منفصل . في حالة الشرائح 8 بت فإن أي معلومة تنقل من أو إلى المعالج لابد وأن تكون مكونة من ثمانيـــة بتات ، إذا كانت هذه المعلومة مكونة من عدد من البتات أكبر من ثمانية فإنها تتقل علي أكثر من مرة وعلى حسب عدد بتاتها . في حالة الشرائح 16 بتا تكون وحدة التعامل في نقل المعلومات هي 16 بتا ، لذلك فإنه مـن البديـهي.أن نتوقع أن الشرائح 16 بتا تكون أسرع من الشرائح 8 بت لهذا السبب أساسا وأسباب أخدى سنعرفها فيما بعد ، فما بالك الآن بالشرائح 32 بتا والشرائح 64 بتا . لاحظ أن زيادة عدد بتات مسار البيانات لن ينعكس فقط على سرعة التعامل مع الذاكرة ولكنه ينعكس أيضا على سرعة تتفيذ العمليات الحسابية . كلمة أخيرة عن مسار البيانات وهي أن الإشارة عليه يمكن أن تكون خارجة من المعالج إلى الأجهزة المحيطة أو داخلة إلى المعالج من الأجهزة المحيطة.

#### 3-5-2 خطوط التحكم Control lines

هذه الخطوط يختلف عددها من معالج لآخر وعن طريق هذه الخطوط يخبر المعالج أى جهاز من الأجهزة المحيطة (الذاكرة مثلا) الذي تم تحديد عنوانه على مسار العناوين عن الغرض من هذا التعامل ، فقد يكون الغرض من التعامل مع الذاكرة مثلا هو القراءة منها ، أى استقبال معلومة منها ، في هذه الحالية فإن البروسيسور يرسل إشارة إلى الذاكرة على خط التحكم Memory Read, MEMR ألى الذاكرة على خط التحكم بارسال المعلومية تعرف منها الذاكرة أن الغرض من التعامل هو القراءة فتقوم بإرسال المعلومية المطلوبة على مسار البيانات فيتلقاها المعالج . أما إذا كان الغرض من التعامل هو الكتابة أو إرسال معلومة إلى الذاكرة فإن المعالج يقوم بوضع إشارة على الخط Memory Write, MEMW تفهم منها الذاكرة الغرض من التعامل فتتلقى المعلومة من على مسار البيانات . هناك خطان للتحكم بنفس الطريقة للتعامل مع بوابات الإخراج والإدخال . هناك أيضا خطوط المقاطعة التى بها يتم فصل مقاطعة أى برنامج يجرى تنفيذه وخطوط المسك HOLD التى بها يتم فصل البروسيسور عن المسارات لأغراض معينة .

| كمية الذاكرة                | عدد خطوط      |
|-----------------------------|---------------|
| التي يمكن التعامل معها      | مسار العناوين |
| 2 بایت                      | 1             |
| 4                           | 2             |
| 8                           | 3             |
| 16                          | 4             |
| 32                          | 5             |
| 128                         | 7             |
| 256                         | 8             |
| 512                         | 9             |
| 1024 واحد كيلوبايت (اكتب)   | 10            |
| 2 کب                        | -11           |
| 4 كب                        | 12            |
| 8 کب                        | 13            |
| ١٥ کب                       | [4            |
| بے 32                       | 15            |
| 4-6 کب                      | 16            |
| 128 کب                      | 17            |
| 256 کب                      | 18            |
| 512 کب                      | 19            |
| 1024 کب (1 میجابایت ، امب)  | 20            |
| بام 2                       | 21            |
| 4 مب                        | 22            |
| 8 ملب                       | 23            |
| 16 مب                       | 24            |
| 32 مب                       | 25            |
| 64 مب .                     | 26            |
| 128 مب                      | 27            |
| 256 مب                      | 28            |
| 512 مب                      | 29            |
| 1024 مب (1 جيجابايت ، 1 جب) | 30            |
| 2 جب                        | 31            |
| 4جب                         | 32            |
| 8 جب                        | 33            |
| 16 جب                       | 34            |
| 32 جب                       | 35            |
| 64 جب                       | 36            |
|                             |               |

جدول 2-3 عدد خطوط مسار العناوين وكمية الذاكرة

هذه الأطراف وغيرها سيأتي الكلام بالتفصيل عنها فيما بعد نظررا لأن عددها وشكل الإشارة عليها يختلف من معالج لآخر . من أهم الأطراف التي يجب أن

نأخذ فكرة عنها هي طرف التزامن CLOCK وعلى هذا الطرف يتم إدخال نبضات كهربية بمواصفات معينة وتردد معين يحدد على حسب نسوع شريحة المعالج . هذه النبضات CLOCK هي ساعة التوقيت الخاصة بالمعالج حيث يحدد زمن تتفيذ أى عملية يقوم بها المعالج بعدد معين من هذه النبضات يجب ألا تتعداه ، ولذلك فإن تردد هذه النبضات يعتبر خاصية من الخواص التي يعسرف بها المعالج حيث بها أساسا تحدد سرعة المعالج . في حالة المعالجات 8 بت يكون تردد التزامن CLOCK اثنين ونصف ميجاهرتز تقريبا قد تزيد أو نقل من تقريباً ، فإذا علمنا أن عملية جمع مسجلين مثلا تتم بعد 7 من هذه النبضات فلن ذلك يعنى أن عملية جمع المسجلين ستتم في زمن مقداره ثلاثة ونصف ميكر وثانية! ، فما بالك بالمعالجات التي تبلغ نبضات الساعة لـــها الآن 400 أو 500 ميجاهرتز . جدول 2-3 يبين عدد خطوط مسار العناوين ومسار البيانــات في بعض المعالجات ، وكذلك سنة ظهور كل واحد منها . هذا الجدول يبين أيضا كمية الذاكرة التي يمكن لكل معالج من هذه المعالجات أن يتعامل معها . يبين الجدول أيضا تردد نبضات الساعة لكل معالج كمقياس لسرعة تنفيذ الأوامر . حاول دراسة هذا الجدول لتتبين التطور السريع في بناء المعالجات.

| تردد نبضات  | المدى       | مسار     | مسار     | عرض      | سنة    | رقم المعالج |
|-------------|-------------|----------|----------|----------|--------|-------------|
| الساعة      | العنواني    | البيانات | العناوين | المسجلات | الظهور |             |
| 2م هرتز     | 64 ك بايت   | 8 بت     | 16 بث    | 8 بت     | 1974   | 8080        |
| 2م هرتز     | 64 ك بايت   | 8 بت     | 16 بت    | 8 بت     | 1976   | 8085        |
| 2-4 م هرتز  | 64 ك بايت   | 8 بت     | 16 بت    | 8 بت     | 1977   | Z80         |
| 6–16 م هرتز | 1 م بایت    | 16 بت    | 20 بت    | 16 بت    | 1978   | 8086        |
| 6–16م هرنز  | 1 م بایت    | 16 بت_   | 20 بت    | 16 بت    | 1980   | 80186       |
| 12−22م هرتز | 16 م بایت   | 16 بت    | 24 بت    | 16 بت    | 1982   | 80286       |
| 16−46م هرتز | 16 م بايت   | 16 بت    | 24 بت    | 32 بت    | 1985   | 80386       |
| 25–66م هرتز | 4 ج بایت    | 32 بث    | 32 بت    | 32 بت    | 1989   | 80486       |
| 200–60م     | 4 ج بایت    | 64 بت    | 32 بت    | 32 بت    | 1993   | Pentium     |
| هرتز        |             |          |          |          |        |             |
| 200–150 م   | 64 ج بایت   | 64 بت    | 36 بت    | 32 بت    | 1995   | Pentium     |
| هرتز        | * . I * 1 m | et       | ba ba    |          |        | Pro         |

جدول 2-3 معلومات عامة عن المعالجات التي سيتناولها هذا الكتاب

# 6-2 شرائح المعالجات ذات 8 بت 8 bit microprocessors

سندقق النظر في هذا الجزء على تركيب شريحتين من شرائح الجيل الثانى من المعالجات وهي الشرائح Intel8085 و Z80 ولقد اختيرت هذه الشرائح بالذات لأنها هي الأكثر استخداما وكانت وما زالت الأسهل في التعليم والأبسط في التركيب والأنسب لتقديم فكرة المعالج وكيفية عمله وبرمجته للمتعلمين الجدد في هذا المجال.

#### 1-6-2 الشريحة Intel8085

شكل (2-5) يبين المحتويات التفصيلية لشريحة المعالج 8085 ومن هذا الشكل يمكننا ملاحظة الأتى :

الدخظ وجود الحد الأدنى من المسجلات والعدادات الذى ذكرناه من قبل و هو مسجل تراكم واحد A وعداد برنامج PC ومسجل ومشفر للأوامــر IR ومسجل مكدسة SP ومسجل حالة SR بالإضافة لوحدة الحساب والمنطـــق وســتة مــن المسجلات العامة .

2. لاحظ وجود مسجل للعناوين Address register وهذا المسجل 16 بت يحتوى عنوان أى مكان فى الذاكرة يراد التعامل معه . النصف العلوى من أى عنوان A15-A8 يخرج من مسجل العناوين إلى خارج الشريحة مباشرة من خلال عازل Buffer ، وأما النصف الأول A0-A0 فإنه يدخل أو لا على مازج Buffer يقوم بدمج إشارة هذه الخطوط فى تتابع زمنى محدد مع الإشارة القادمة من مسار البيانات وإرسال الإشارتين على نفس الخطوط حيث تخرج إلى خارج الشريحة من خلال عازل أيضا . إن عملية المزج هذه التى يقوم بها تقليل عدد أرجل الشريحة وأما كيفية فصل الإشارتين ثانية فسوف يتم الحديث عنه بالتفصيل فى فصل قادم .

3. عدد الأطراف الخارجة من الشريحة 40 طرفا سيأتى الحديث عن كل طرف وشكل الإشارة الموجودة عليه فى فصل قادم أيضا إن شاء الله . الخط المنقط فى شكل (2-5) عبارة عن حدود للشريحة يبين الأطراف الخارجة منها والتى من خلالها يتم الاتصال بين خارج الشريحة وداخلها . اتجاه السهم على هذه الخطوط يبين أيضا اتجاه الإشارة على كل منها إذا كانت داخلة للمعالج أم خارجة منه .

#### 280 المعالج 2-6-2

كما نلاحظ من شكل (2-6) فإن أساس تركيب الشريحة Z80 هو نفسه أساس تركيب الشريحة Intel8085 من حيث وجود المسجلات الأساسية مثل عداد البرنامج ومسجل ومشفر الأوامر ومسجل التراكم وعدد من المسجلات العامة

ووحدة الحساب والمنطق ووحدة التحكم والتزامن ، لكن كما ذكرنا من قبل دائما تكون هناك بعض الاختلافات عن هذا الأساس وتتمثل هذه الزيادات في حالة الشريحة Z80 فيما يلى:



1. معظم مسجلات الشريحة Z80 تم مضاعفتها فهناك مثلا مسجلين التراكم A و A و مسجلين الحالة SR و SR و جميع المسجلات العامة تـم مضاعفتها

أيضا كما هو موضح في شكل (2-6) وذلك سيكون له ميزة عظيمة في عملية البرمجة كما سنرى  $\cdot$ 

2. تم زيادة المسجلين IX و IY وكل منهما 16 بت وهذان المسجلان يستخدمان في طرق مختلفة لعنونة الذاكرة كما سيتضبح فيما بعد .



- 3. تم زيادة عداد إنعاش الذاكرة والذى يستخدم فـــى عمليــة إنعـاش الذاكـرة الديناميكية لأنه كما نعلم فإن الذاكرة الديناميكية تحتاج دائما لعمليـــة تجديــد أو إنعاش أو إعادة تخزين لمحتوياتها بعد فترات زمنية محددة وإلا فإنها تفقدها بعــد زمن مقداره بعض ميللثانية .
- 4. نظرة شاملة على الأطراف الخارجية للمعالج Z80 سنجد أن له عدد 40 طرفا لها تقريبا نفس الوظائف الخاصة بــاطراف المعالج Intel8085 وإن اختلفت المسميات وسنعرف ذلك بالتفصيل عند دراسة الخواص والوظائف المختلفة لكل

طرف . الخط المنقط فى شكل (2-6) عبارة عن حدود للشريحة يبين الأطراف الخارجة منها والتى من خلالها يتم الاتصال بين خارج الشريحة وداخلها . انجله السهم على هذه الخطوط يبين اتجاه الإشارة على كل منها إذا كانت داخلة للمعالج أم خارجة منه .

## 7-2 تـمـاريــن

- 1. اذكر المهام الأساسية التي من المفروض أن يقوم بها أي معالج ؟
  - 2. لماذا يعتبر مسجل التراكم من أهم المسجلات في المعالج ؟
- 3. كم عدد بتات مسجل التراكم في المعالجات التي ندرسها في هـــذا الكتــاب؟
   ولماذا هذا العدد بالذات؟ وماذا يحدث لو نقص هذا العدد أو زاد؟
- 4. هل تصنف مسجل التراكم من المسجلات عامة الأغراض general purpose .4 و dedicated registers أم المسجلات خاصة الأغراض registers
- 5. ما هى وظيفة عداد البرنامج PC ؟ وكم عدد بتاته ؟ ولماذا يرتبط عدد بتاتــه
   بعدد بتات مسار العناوين ؟
- 6. ماذا يحدث لو أن عدد بتات عداد البرنامج كان ثمانية بدلا من 16 في المعالجات التي ندرسها ؟ وماذا يحدث لو أن هذا العدد كان 20 مثلا ؟
- 7. ما هى وظيفة مسجل الأوامر IR ؟ وكم عدد بتاته ؟ وهل يرتبط هذا العسدد بمسار البيانات data bus أم بمسار العناوين address bus ؟
- 8. ما هى وظيفة مسجل الحالة SR ؟ اذكر الأعلام الموجودة فى مسجل الحالــة للمعالج الذى تهتم بدر استه فى هذا الكتاب ، ومتى يكون كل علم من هذه الأعلام واحدا ومتى يكون صفرا ؟
- و. هل مسجل الحالة ومسجل الأوامر وعداد البرنامج تصنف على أنها مسجلات عامة الأغراض أم خاصة الأغراض ؟
- 10. على ضوء المهام المنوطة بالمعالج ، هل تشعر أن أيا من المسجلات السابقة يعتبر زائدا ويمكن الاستغناء عنه ؟
  - 1 1. ما هي محتويات كل علم من الأعلام بعد إجراء العمليات التالية :

10101111 10101111 01101110 11011101 11110001 XOR 11110001 AND 00101111- 10011001+

12. هل يحتوى المعالج الذى تهتم بدراسته على مسجلات عامة الأغراض غيير مسجل التراكم ؟ أذكر هذه المسجلات ، وما فائدتها ؟ وهل يمكن الاستغناء عنها؟ 13. وضح بالرسم تركيب المعالج الذى تهتم بدارسته ؟

- 4]. الكلية التى ندرس بها فيها 200 عضوا هيئة تدريس ، مطلوب إعطاء شــفرة ثنائية لكل واحد منهم ، وكم سيكون عدد بتات هذه الشفرة ؟ هذه الشفرة الثنائية ، هل يمكن التعارف على أنها بمثابة عنوان للشخص ؟
- 15. شفرة ثنائية مكونة من 5 بتات ، كم عدد العناوين التي يمكن تشفيرها بهذا العدد من البتات ؟
  - 16. كم عدد الخطوط (البتات) في مسار العناوين في المعالج الذي تدرسه ؟
    - 17. ما مقدار كمية الذاكرة التي يستطيع أن يتعامل معها هذا المعالج؟
  - 18. ما هو تأثير زيادة أو نقصان عدد الخطوط في مسار العناوين لأي معالج؟
- 19. لدينا 16 راكبا نريد نقلهم من مكان إلى مكان آخر باستخدام أتوبيس يسلع 8 ركاب فقط ، كم عدد المشاوير التى سيقوم بها الأتوبيس ؟ لو استخدمنا أتوبيس يسع 16 راكبا ويسير بنفس سرعة الأول ، كم سيكون على د المشاوير؟ وأى الوسيلتين أسرع؟
- 20. لو شبهنا الأتوبيس بمسار البيانات للمعالج ، وسعة الأتوبيس بعدد البتات (الخطوط) في هذا المسار ، أيهما سيكون أفضل من حيث السرعة في نقل المعلومات ، المعالج ذو 8 بتات أم ذو 16 بتا ؟

# الفصلالثالث

برمجة المعالج

Microprocessor Programming

## 1-3 مقدمة

بعد أن أخذنا فكرة عامة عن وظيفة ومهمة كل مسجل من مسجلات شريحة المعالج سنتعرض في هذا الفصل وبعض الفصول القادمة إلى كيفية برمجة هذه الشريحة وهذا هو الشق الأول من دراسة شرائح المعالجات كما ذكرنا، وأما الشق الآخر وهو مواجهة المعالج فإن ذلك سيكون في فصول قادمة أخرى إن شاء الله. سنتعرض في هذا الفصل لدراسة الأفكار العامة عن لغة التجميع (الأسمبلي) دون أن نخص بالذكر أي شريحة معينة حيث سيعقب هذا الفصل فصل خاص بلغة الأسمبلي والأوامر الخاصة بكل واحدة من شرائح المعالج المدالية عدى المعالج و Z80 .

## 2-3 لغات الحاسب Computer languages

لغات الحاسب يمكن تقسيمها إلى قسمين أساسبين:

القسم الأول: وهو اللغات التي تعتمد على الماكينة معينة وما يتوافق منها languages وكل لغة من هذا النوع تكون مصممة لماكينة معينة وما يتوافق منها مع ماكينة معينة ليس بالضرورة أن يتوافق مع الماكينات الأخرى . من أمثلة هذا النوع من اللغات ، لغة الماكينة machine language ولغة الأسمبلي language حيث أن كل معالج له مجموعة الأوامر الخاصة به التي عادة لا تتوافق مع المعالجات الأخرى . فأنت مثلا إذا كتبت برنامجا بلغة الأسمبلي الخاصة بالشريحة الشريحة المرافعة الإرامج لا يمكن أن ينفذ مع الشريحة الشريحة الشريحة المرافعة المرافعة المرافعة المرافعة المرافعة الشريحة المرافعة المرافعة

القسم الثانى: هو اللغات التى لا تعتمد على الماكينة هو اللغات التى لا تعتمد على الماكينة high level ومن أمثلة هذه اللغات جميع اللغات ذات المستوى العالى العالى العالى العالى العالى العالى و PL/C وغير ذلك من هذه اللغات التى تعد بالمئات الآن .

# 3-3 ما هو الأمر؟

الأمر معناه الكود أو الشفرة الثنائية التى تعطى للمعالج والتى على أثرها يقوم بعمل فعل معين . هذا الفعل قد يكون عملية جمع رقمين أو إحضار معلومة من الذاكرة أو غير ذلك من الأفعال التى يستطيع المعالج القيام بها . من أمثلة هنده الشفرات الثنائية الشفرة 10000000 والتى معناها اجمع محتويات المسجل B مع

مسجل التراكم A وضع النتيجة في المسجل A . كما نرى فإن المعالج يتعسرف فقط على الشفرات الثنائية و لا يعرف أى نوع آخر من الشفرات سواء كانت حرفية أو ثمانية أو ستعشرية . لقد سبق تعريف كل من الأمر والبرنامج في الفصل الأول بصورة عامة ولكننا أعدنا تعريفهما في هذا الفصل بشيء من التفصيل .

## 3-4 ما هو البرنامج ؟

شكل (3-1) برنامج يجمع محتويات العنوان 60H مع العنوان 61H شكل ويضع النتيجة في العنوان 62H

# 3-5 كيف يقوم المعالج بتنفيذ البرنامج ؟

شكل (2-2) يبين الخطوات التي يقوم بها المعالج لكي يتم تنفيذ أي برنامج وهيي كالتالي:

يقوم المعالج (وحدة التحكم بداخله) بقراءة الأمر الأول من الذاكرة وتخزينه في مسجل الأوامر IR.



2. يقوم المعالج بفك شفرة هذا الأمر أو بمعنى آخر يتم التعرف على هذا الأمر من بين قائمة أوامر المعالج √ وعلى ضوء هذا التعارف يقرر المعالج إذا كران هذا الأمر سيحتاج لمعلومات أخرى من الذاكرة لكى تتم عملية التنفيذ أم لا ؟ وإذا كان الأمر سيحتاج لمثل هذه المعلومات يقوم المعالج بإحضارها أيضا من الذاكرة. بذلك تتتهى المرحلة الأولى من مراحل تتفيذ الأمرار الأول وهي مرحلة الإحضار fetching cycle .

3. بمجرد الانتهاء من مرحلة أو دورة الإحضار تبدأ مرحلة التنفيذ execution حيث يقوم مشفر الأوامر مع وحدة التحكم بإرسال الإشارات المناسبة إلى وحدة الحساب والمنطق التي تقوم بتنفيذ هذا الأمر.

4. بعد الانتهاء من مرحلة تتفيد الأمر الأول يرجع المعالج إلى الخطوة الأولى حيث يبدأ في عملية إحضار الأمر الثاني ثم يتم تنفيذه ثم يبدأ في عملية إحضار الأمر الثالث وتنفيذه وهكذا حتى ينتهى البرنامج .

## 6-3 طريقة كتابة البرنامج للمعالج

## Binary codes الشفرات الثنائية 1-6-3

إن الناظر لأول وهلة في البرنامج المكتوب بلغة الماكينة في شكل (-1) سيصاب بالذهول وسيقول: هل من المعقول أن أكتب كل هذا العدد من الوحسايد والأصفار في برنامج لا يتعدى الأربع خطوات ? بالطبع إن ذلك حق لأن كتابة البرامج بلغة الماكينة تصاحبها بعض العيوب والتي نوردها فيما يلى:

1. هذه البرامج تأخذ وقتا طويلا في إدخالها للذاكرة لأننا نكتبها بت بُعد بت .

2. مثل هذه البرامج من الصعب فهمها أو متابعتها أو تصحيح أى خطا فيها و ذلك لأن الأعداد الثنائية عبارة عن نمازج من الوحايد والأصفار التى يصعب النفريق بينها خاصة بعد فترة عمل طويلة مع هذه الأرقام.

3. شكل هذا البرنامج لا يعطى أى دلالة على الغرض منه ، على العكس من برامج الباسيك أو حتى الأسمبلي كما سنرى بعد قليل فإنه بعد نظرة فاحصة على البرنامج تستطيع أن تخبر ما الغرض منه .

4. من السهل أن يقع المبرمج في الكثير من الأخطاء أثناء كتابة هـذه الـبرامج
 ومن الصعب عليه جدا استخراج هذه الأخطاء قيما بعد .

كمثال على ذلك سنكتب البرنامج السابق الموجود في شكل (-1) مرة أخرى في شكل (-3) وبجانبه صورة منه تحتوى على خطأ معين وحاول استخراج هـذا الخطأ!! ما رأيك الآن لو كان البرنامج مكونا من عشرات أو حتى مئات من السطور هل تستطيع استخراج أخطأته كلها ؟ لاحظ أنك في شكل (-3) أمامك الصورة الصحيحة والصورة الخطأ وأنت فقط تقارن الاثنين ولكن عادة في الوضع الحقيقي فإنه لن تكون أمامك الصورة الصحيحة للبرنامج ولكنك أخبرت بأن البرنامج به خطأ وعليك استخراجه ، بالطبع فإن هذه ستكون عملية شاقة .

## Hexadecimal codes الشفرات الستعشرية 2-6-3

من الممكن تسهيل عملية كتابة البرامج بلغة الماكينة عن طريق استخدام نظام آخر غير النظام الثنائي وليكن مثلا النظام الستعشري أو النظام الثماني وسنعرض

هنا للنظام الستعشرى فقط على أساس أنه الأكثر شيوعا وأنه الأسهل في عملية الكتابة لأن عدد خانات العدد بالنظام الستعشرى تكون عادة أقل منها في النظام الثماني .

| 00111010 | 00111010 |
|----------|----------|
| 01100000 | 01100000 |
| 00000000 | 00000000 |
| 01000111 | 01000111 |
| 01110010 | 00111010 |
| 01100001 | 01100001 |
| 00000000 | 0000000  |
| 10000000 | 10000000 |
| 00110010 | 00110010 |
| 00110010 | 00110010 |
| 00000000 | 00000000 |

شكل (3-4) يبين برنامج الجمع السابق وقد تمت كتابت هذه المرة بالنظام الستعشرى . من هذا الشكل نلاحظ أن عملية كتابة البرامج باستخدام النظام الستعشرى وكذلك عملية فحص البرنامج واستخراج الأخطاء منه ستكون أسها الستعشرى وكذلك عملية فحص البرنامج واستخراج الأخطاء منه ستكون أسهل وذكرنا أن المعالج لا يعرف سوى الإشارات المكتوبة بالنظام الثنائي فقط (وحايد وأصفار) فما هو الحل وقد كتبنا البرنامج بالنظام الستعشري كما هو في شكل (3-4) وأن الحل لهذه المشكلة هو تحويل هذه الأوامر من الصورة الستعشرية التحويل هذه ؟ بالطبع إذا قام بها المستخدم فقد رجعنا إلى المشكلة الأولى وذلك المعوبة عملية التحويل هذه ؟ بالطبع إذا قام بها المستخدم فقد رجعنا إلى المشكلة الأولى وذلك المعوبة عملية التحويل من الصورة الستعشرية إلى الصورة الستعشرية ألى المناع بناهم المهمة مهمة التحويل من الصورة الستعشرية المهمة مهمة التحويلها إلى النظام الشعشري ثم يقوم هو (البرنامج) بتحويلها الى النظام الشعشري ثم يقوم هو (البرنامج) بتحويلها الى النظام الشعشري المهاء المعلام الستعشري ثم يقوم هو (البرنامج) بتحويلها الى النظام الشعشري ثم يقوم هو (البرنامج) بتحويلها الى النظام الشعشري المهاء المعلودة المناه الستعشري المهاء الستعشري المهاء الستعشري المهاء المعالم النظام الستعشري المهاء المهاء المناه الستعشري المهاء المهاء المعاهم النظام الستعشري المهاء المها

لقد حل النظام الستعشرى مشكلة صعوبة كتابة البرامج واستخراج الأخطاء منها إلى حد ما ، ولكن بقيت المشكلة الأخرى وهي أننا ما زلنا نتعامل مع أرقام صماء

كشفرات للأوامر لا تحمل أى دلالة عن ماذا يفعل هذا الأمر أو ذاك . فمثلا الرقم 3A هو شفرة لأمر معين ولكننا لا نستطيع مثلا أن نميز ذلك الأمر فقد يكون هذا الرقم مثلا جزءا من عنوان كالأرقام 60,61,62 وغيرها ، وحتى إذا عرفنا أنهة شفرة لأمر فلن نستطيع معرفة ماذا يفعل هذا الأمر إلا إذا رجعنا إلى كتالوج خاص بذلك .

```
3A

60

00

47

3A

61

00

80

32

62

00

شكل (3-3) نفس البرنامج الموجود في شكل (3-3) ولكن مكتوب

بالنظام الستعشري
```

## 3-6-3 الشفرات الحرفية Mnemonics codes

إنها لفكرة عظيمة لو أننا فهمنا المقصود من كل أمر من الأوامر وأعطينا كل واحدا منها كودا أو شفرة مكونة من ثلاثة أو أربعة أحرف على الأكثر على تكون هذه الأحرف من الأحرف الأبجدية التي تدل تقريبا على ما يقوم به المعللج عند تنفيذ هذا الأمر . فمثلا أمر الجمع يكون ADD التي هي اختصارا لكلمة Addition يعني جمع ، وأمر الطرح يكون SUB وجاءت من Subtraction بمعني طرح ....و هكذا مع باقي الأوامر كما سنري فيما بعد . إن هذه الاختصارات هي ما يسمى بلغة الأسمبلي Assembly language أو أحيانا تسمى Mnemonics codes بمعنى الشفرات التي من السهل تذكرها حيث كلمة mnemonics تعنى المساعد لعملية التذكر ، وهي كذلك في الحقيقة ، إذ الآن بوضع الأوامر في هذه الصورة الحرفية أصبح من السهل تذكرها بل ومن السهل أن تخبر ماذا يفعل الأمر بمجرد النظر إليه . ما أروعها لو أن العرب قد سبقوا في هذا المجال وفرضوا الكلمات طرح وجمع بدلا من SUB و CDD ....!

يقوم كل صانع الشريحة من شرائح المعالج بتزويدها بقائمة أو كتالوج يحتوى كلى هذه الاختصارات الحرفية mnemonics ، ولذلك فإنك ستجد أن اختصارات كل

شركة منتجة تختلف عن اختصارات الشركات الأخرى وسوف نرى ذليك في الفصول القادمة إن شاء الله . إن أى برنامج مكتوب بهذه الاختصارات يقال عنه أنه مكتوب بلغة الأسمبلي . شكل (3-5) يبين البرنامج الموجود في شكل (3-4) والذي سبق كتابته بالشفرات الستعشرية وقد كتبت جميع أو امره هذه المرة بلغية الأسمبلي لأحد المعالجات ، انظر لهذا البرنامج وحاول توقع ماذا يفعل كل أمسر من هذه الأوامر قبل أن ندرسها بالتفصيل .

نحن هنا أيضا أمام مشكلة ترجمة هذه الشفرات الحرفية المعالج ، وكما هي الحال يستطيع المعالج التعرف عليها إلى شفرات ثنائية يعرفها المعالج ، وكما هي الحال مع الشفرات الستعشرية فإننا سنترك أمر هذه الترجمة ليقوم بها المعالج نفسه عن طريق برنامج مكتوب لهذا الغرض يقوم المعالج بتنفيذه فيحول هدذه الشدفرات الحرفية إلى الشفرات الثنائية المطلوبة . هذا البرنامج يطلق عليه الأسمبلر المحتوب بلغة الأسمبلر هو برنامج مكتوب بلغة الماكينة يقوم بتحويل البرنامج المكتوب بلغة الأسمبلي (الشفرات الحرفية) إلى البرنامج مكتوب بلغة الأسمبلي (الشفرات الحرفية) إلى المنامج مكتوب بلغة الأسمبلي والمحتوب بلغة الأسمبلي المحتوب المكتوب بلغة الأسمبلي المحتوب المكتوب المنافق على البرنامج المكتوب المنافق الماكينة "برنامج المحتوب المنافق على البرنامج المكتوب المنافق الماكينة "برنامج المحتوب المنافق الماكينة "برنامج المحتوب المنافق الدور الذي يقوم به الهدف" object program . شكل (3-6) يبين رسما توضيحيا للدور الذي يقوم به الأسمبلر .

إن المقابل الذي يدفعه المستخدم نتيجة استخدامه للغة الأسمبلي يكون أو لا في كمية الذاكرة التي يشغلها برنامج الأسمبلر حيث أن هذا البرنامج لابد وأن يشغل كمية من الذاكرة الأساسية للميكروكومبيوتر وثانيا بعض التأخير الدذي يحدث نتيجة الوقت الذي يأخذه الأسمبلر في عملية الترجمة . وكما نعرف فإنسه ليس هناك شيء كامل على الإطلاق ، لذلك فإننا نستطيع أن نلخص بعض عيوب لغة الأسمبلي فيما يلي :

1. مازالت هذه الاختصارات الحرفية غير كافية للدلالة على معنى الأوامر المختلفة حيث مازالت صبغ الأوامر بعيدة كل البعد عن اللغة العادية التنى يستخدمها الإنسان وأيضا بالمقارنة بأوامر اللغات ذات المستوى العالى فإن لغة الأسمبلى تعتبر الأصعب في التعلم.

2. لكى تستخدم هذه اللغة لابد من المعرفة الكاملة بمكونات المعالج ، المسجلات الموجودة بداخلة ، وطريقة المعالج فى التعامل مع الذاكرة وغير ذلك من الأمور الغير موجودة فى اللغات ذات المستوى العالى .

3. هذه اللغة كما ذكرنا من قبل تعتبر من اللغات التي تعتمد على الماكينة ، فأنت إذا كتبت برنامجا للمعالج Z80 فلن تستطيع استخدامه مع المعالج MC6800 مثلا.





# High level languages اللغات ذات المستوى العالى 7-3

لقد تم التغلب على الكثير من الصعوبات والعيوب المصاحبة للغة الأسمبلى باستخدام اللغات ذات المستوى العالى . إن كل أمر من أو امر أى لغة من هذه اللغات يدل أو يقوم بعملية مركبة على عكس لغة الأسمبلى فإن كل أمر فيها يقوم بعملية أولية . فمثلا برنامج الجمع السابق الذي يجمع رقمين موجودين في الذاكرة والذي تمت كتابته في أحد عشر سطرا باستخدام لغة الأسمبلي يمكن كتابته في سطر واحد باستخدام لغة الباسيك كما يلى :

SUM = NUM1 + NUM2

لذلك فإن أى أمر من أوامر أى لغة من اللغات ذات المستوى العالى هو فى الحقيقة مجموعة من أوامر لغة الأسمبلى . إن ما يقوم به برنامج الأسمبلر فلم حالة لغة الأسمبلى يقوم به برنامج المراحف أو الجامع أو المصنف compiler program فى حالة اللغات ذات المستوى العالى ، حيث يقوم هذا المؤلف بترجمة الأوامر المكتوبة باللغات ذات المستوى العالى إلى لغة الماكينة أو الشفرات الثنائية التى يقبلها المعالج . هذه اللغات ليست موضوع دراستنا فى هذا الكتاب لذلك سنكتفى بهذا القدر من الكلام عنها .

# 3-8 خطوات كتابة برنامج بلغة الأسمبلي

الآن وقد عرفنا الفرق بين لغة الماكينة ولغة الأسمبلي فبائي صدورة سنكتب برامجنا ؟ الإجابة على ذلك ستتوقف على إمكانيات الميكروكومبيوتر الذي تتعامل معه سواء في بيتك أو في معملك . إذا كان لديك برنامج الأسمبلر فإنه بالطبع من الأفضل أن تكتب برامجك بلغة الأسمبلي على الحاسب بنفس الشكل ثم تطلب من الأسمبلر أن يقوم بعملية الترجمة وإدخال البرنامج إلى الذاكرة ، أما إذا لم يكن لديك أسمبلر فليس أمامك من خيار سوى الكتابة بلغة الماكينة أو الشفرات الستعشرية في الذاكرة مباشرة . شكل (3-7) بيين خريطة تدفق أو مخطط سير المعالج .

السؤال الآن في أي مكان في الذاكرة سنضع البرنامج ؟

للإجابة عن هذا السؤال يجبب أن نتصبور الذاكرة الخاصة بالجهاز أو الميكروكومبيوتر الذى نستخدمه وقد قسمت إلى ثلاثة أجزاء كالموضحة فى شكل (8-8) . الجزء الأول منها هو ROM أو ذاكرة القراءة فقط وهذه كما ذكرنا فى الفصل الأول لا يمكن للمستخدم أن يسجل فيها أى شيء . الجزء الثانى مسن الذاكرة هى RAM وهى الجزء الذى يمكن للمستخدم أن يتعامل معه ويجبب أن نعلم أن نظام التشغيل الخاص بالجهاز الذى نستخدمه يحجز جزءا من هذه RAM للاستعمال الخاص به والجزء المتبقى يمكن للمبرمج أن يستخدمه . لذلك يجبب قبل أن تبدأ فى كتابة برنامجك بلغة الأسمبلى وإدخاله فى الذاكرة أن تعرف أيس يقع جزء RAM الخاص بنظام التشغيل حتى لا يتداخل البرنامج الخاص بك معه. إن ذلك يتطلب إلقاء نظررة على ما يسمى بخريطة الذاكرة الخاصة الخاصة بالميكروكومبيوتر الذى تستخدمه . هذه الخريطة تعتبر شكلا توضيحيا يبين بالميكروكومبيوتر الذى تستخدمه . هذه الخريطة تعتبر شكلا توضيحيا يبين الذاكرة بأكملها من الأول حتى آخر بايت وقد قسمت إلى أجزاء مع التعريف بكل الذاكرة بأكملها من الأول حتى آخر بايت وقد قسمت إلى أجزاء مع التعريف بكل جزء فيما يستخدم وهل هو مشغول أم لا . الآن وقد عرفت الجزء مسن RAM الذى يمكنك أن تضع فيه برنامجك يجب عليك كمبرمج أن تقسم هذا الجزء إلى الذى يمكنك أن تضع فيه برنامجك يجب عليك كمبرمج أن تقسم هذا الجزء إلى

جزأين أيضا ، أحدهما تكتب فيه البرنامج والآخر تخصصه للبيانات التي يحتاجها أو يخرجها البرنامج .



إن عملية تقسيم الذاكرة إلى جزء للبرنامج وآخر للبيانات عملية تعتمد على المبرمج بالدرجة الأولى وعلى البرنامج أيضا ، فقد يكون البرنامج لا يحتاج إلى بيانات أو لا يخرج بيانات على الإطلاق ، في هذه الحالة فإن كل RAM ستكون للبرنامج ، وقد يكون البرنامج ينتج أو يحتاج للكثير من البيانات ، في هذه الحالة يجب حجز جزء كاف لهذه البيانات .



#### مثال 3. 1

لدينا مجموعة من الأرقام وليكن عددها 50H رقما ، والمطلوب استخراج أكـــبر عدد في هذه المجموعة . أين سنكتب البرنامج ؟ وأين سنكتب البيانات (الخمسين رقما) ؟

كما نرى من شكل (3-8) فإن جزء RAM المخصص للمستخدم في الميكروكومبيوتر الذي نستخدمه بيداً من العنوان E000H وينتهى عند العنوان FC00H وينتهى عند العنوان FC00H . هذه المساحة من RAM يجب أن نقسمها إلى جزء للبرنامج وجزء للبيانات . البيانات المطلوبة هي 60 t رقما ويمكن لنا أن نضعها ابتداء من العنوان E150H حتى العنوان E150H . أما البرنامج فيمكن لنا أن نكتبه مثلا ابتداء من العنوان E000H على أساس أن البايتات التي سيحتاجها البرنامج نفسه لن يصل عددها إلى 100H بايت بأي حال من الأحوال وإلا لو زاد عددها عدن ذلك فسوف تتداخل مع البيانات عند العنوان E100H وفي هذه الحالة يجب أن نزيح البيانات بعيدا أو نكتب البرنامج بعد البيانات .

عملية تقسيم الذاكرة الموضحة في شكل (8-8) يسمى في مصطلحات الحاسبات بخريطة الذاكرة حيث يبين هذا الشكل جميع الذاكرة الملحقة بالجهاز الدي تستخدمه وفيما يستخدم كل جزء منها ، وهذه الخريطة يجب على أي مستخدم للغة الأسمبلي أن يتعرف عليها جيدا بالنسبة للحاسب الذي سيستخدمه ، والتقسيم الموضح في شكل (8-8) سيكون هو التقسيم الذي سنتبعه خلل هذا الكتاب وبالطبع فإن هذه الخريطة تختلف باختلاف الجهاز المستخدم فيجب مراعاة ذلك .

## 3-9 تـماريــن

- 1. ما هو الأمر ؟
- 2. ما هو البرنامج ؟
- 3. تخيل أنك تركب سيارة آلية تريد الانتقال بها من المكان (أ) إلى المكان (ب) كما في شكل (3. 9) هذه السيارة عند كل تقاطع لابد أن تأخذ قرارا من أربعة تحدد اتجاه حركتها كما في الجدول الموضح في نفس الشكل . اكتب برنامجا لهذه السيارة بالقرارات ثم بالشفرات الثنائية بحيث عندما تنفذه تنتقل السيارة من المكان (أ) إلى المكان (ب) في الشكل .
  - 4. هل يمكنك إعطاء اسم للغة الشفرات الثنائية المكتوب بها البرنامج السابق ؟
- ماذا يحدث لو جعلنا شفرة القرار تتكون من 3 بتات بدلا من 2 ؟ بالطبع فـــى
   هذه الحالة سيكون هناك إمكانية لعدد أكبر من القرارات يصل إلى 8 ، افــترض
   هذه القرارات من عندك محاولا تطوير هذه السيارة ؟
  - 6. اشرح باستخدام خريطة تدفق كيف يقوم المعالج بتنفيذ أى برنامج؟
    - 7. ما هي عيوب كتابة البرامج بالشفرات الثنائية ؟
- 8. أعد كتابة البرنامج الموجود في شكل (1-3) مستخدما النظام الثماني ؟ كم عدد ضربات المفاتيح التي ستنفذها لكي تكتب البرنامج مستخدما هذا النظام ؟ ملا نوع المحمل loader الذي ستحتاج إليه في هذه الحالة ؟ أيهما أفضل في الكتابة وسهولة استخراج الأخطاء ، النظام الثماني أم النظام الستعشري ؟
  - 9. اشرح فائدة استخدام الأسمبار ؟ ...
- 10. ما هي عيوب البرمجة باستخدام لغة التجميع مقارنة باللغات ذات المستوى العالى ؟
  - 11. اشرح الفرق بين الأسمبلر والمترجم ؟
  - 12. هِلَ لَغَةٍ ٢ من اللغات التي تعتمد على الماكينة ؟
- 13. مطلوب كتابة برنامج يجمع 20 رقما مخزنة في الذاكرة ، ارسم خريطة للذاكرة تبين عليها أين ستكتب البرنامج وأين ستوضع البيانات ؟

14. حاول الحصول على خريطة الذاكرة للميكر وكومبيوتر الذى تتعامل معه وادرسها وطبق عليها المسألة السابقة ؟



# الفصل الرابح

المحبة المعالج 18085 Programming The Intel 8085
Microprocessor

#### 4-1 مقدمة

لبرمجة أى معالج لابد من دراسة مجموعة الأوامر الخاصة به ولكي نسهل دراسة هذه الأوامر سنقوم بتقسيمها إلى مجموعات من حيث الوظيفة التى يؤديها كل أمر وسندرس بالتفصيل فى كل مجموعة بعض الأوامر الكثيرة الاستخدام مع التمثيل ببعض الأمثلة ، على أننا سنعرض فى نهاية الفصل لجداول تحتوى على جميع أوامر الشريحة موضوعة فى مجموعات ثم سنعرض أيضا جدو لا يحتوى هذه الأوامر مرتبة أبجديا مع نبذة بسيطة عن وظيفة كل أمر وشفرته .

# 2-4 مجموعة أوامر الانتقال Transfer instructions

يقوم أي أمر من أوامر هذه المجموعة بنقل معلومة من مكان لآخر حيث المكان الذي تخرج منه المعلومة يسمى بالمصدر Source وسنرمز له بالرمز SSS وهذا المكان قد يكون مسجلا داخل شريحة المعالج وقد يكون مكانا من أماكن الذاكرة وأما المكان الذي ستذهب إليه المعلومة فسوف نسميه الهدف المحلل وسنرمز له بالرمز ddd وهذا المكان أيضا قد يكون مسجلا داخل شريحة المعللج وقد يكون بايت من بايتات الذاكرة كما سنرى . شكل (4-1) يبين أهم الأوامر الموجودة في مجموعة أوامر الانتقال الخاصة بالشريحة 8085 والتي تهمنا فهذه المرحلة من دراسة لغة الأسميلي .

MOV MVI LXI LDA STA LHLD SHLD شكل (1-4) بعض أوامر الانتقال الكثيرة الاستخدام للشريحة 8085

MOV الأمر MOV المر العامة لهذا الأمر هي:

MOV ddd,sss

مسجل sss مسجل

ومعنى هذا الأمر انقل أو حرك (وهذا هو ترجمة كلمة move) المعلومة الموجودة في المصدر sss إلى الهدف ddd ، لاحظ أن المعالج عندما يقوم بنقل معلومة فإنه ينقل صورة منها فقط أما أصل المعلومة فيظل في المصدر ولا يتغير . الصورة العامة لشفرة هذا الأمر الثنائية يمكن كتابتها كما يلي :

01dddsss

حيث 888 تستبدل بشفرة مصدر المعلومة سواء كانت مسجلا أم ذاكرة و ddd تستبدل أيضا بشفرة الهدف الذى ستلجأ إليه المعلومة سواء كان مسجلا أم ذاكرة. لاحظ أن هذا الأمر يتكون دائما من بايت واحدة . راجع شفرات المسجلات في الفصل الثاني ، جدول 2-1 ، وانظر المثال التالى :

### مثال <del>1-</del>4

1. الأمر MOV A,B

شفرته الثنائية هي 01111000

شفرته الستعشرية هي 78H

هذا الأمر سينقل محتويات المسجل B (صورة منها فقط) إلى المسجل A لاحظ أن المسجل B هو المصدر  $_{\rm SSS}$  ولذلك استبداناه بشفرته الثنائية وهى 000 والمسجل A هو الهدف ddd واستبدلناه بشفرته الثنائية  $_{\rm SSS}$  النشاء بشفرته الثنائية  $_{\rm SSS}$  النظام الستعشرى ، ولمزيد من الأمثلة إليك ما يلى :

2. الأمر MOV L,D

شفرته الثنائية هي 01101010

شفرته الستعشرية هي 6AH

3، الأمر MOV C,C

شفرته الثنائية هي 01001001

شفرته الستعشرية هي 49H

هذا الأمر ينقل محتويات المسجل C إلى نفسه وهذا يكافئ تماما ، لا تعمل شيئا . مثل هذه الأوامر التي لا تعمل شيئا لها أهمية كبيرة في الكثير من التطبيقات كما سيأتي فيما يعد .

فى جميع الأوامر السابقة كنا ننقل المعلومة من مسجل إلى مسجل آخر ، ماذا لـو أردنا نقل معلومة من مسجل إلى الذاكرة أو العكس . المثال التالى سيوضح ذلك .

#### مثال 4-2

ا. الأمر MOV M,A

شفرته الثنائية هي 01110111 شفرته الستعشرية هي 77H

هذا الأمر ينقل محتويات المسجل A وهو مصدر المعلومة إلى الذاكرة M وهي الهدف الذي ستذهب إليه المعلومة ، لاحظ أن M استبدلت بالشفرة 110 كما في جدول 1-2 . السؤال الآن هو : في أي مكان أو في أي عنوان في الذاكرة بستذهب محتويات المسجل A ? في جميع الأوامر التي تتعامل مع الذاكرة بسهذا الشكل يكون العنوان موجودا في زوج المسجلات H ، أي أن محتويات المسجل A ستذهب إلى بايت الذاكرة التي يوجد عنوانها في المسجلين H و A . لاحظ أن هذه الطريقة هي ما سنسميها بطريقة التعامل غير المباشر مع الذاكرة عندما سنصنف طرق التعامل مع الذاكرة في نهاية هذا الفصل .

MOV B,M .2 01000110 46H

هذا الأمر سينقل محتويات بايت الذاكرة التي يوجد عنوانها في المسجلين H و L المسجل B .

### 2-2-4 الأمر MVI

هذا الأمر معناه "انقــل المعلومـة الفوريـة" أى Move the Immediate data والصورة العامة له هي:

MVI ddd,data8 ddd ← data8

هذا لأمر يضع المعلومة المكونة من ثمانية بتات (data8) في الهدف ddd الهدف ddd في السهدف ddd الهدف ddd قد يكون مسجلا أو الذاكرة M كما سنرى في الأمثلة . هذا الأمر يتكون دائما من اثنتين من البايتات . واحدة هي شفرة الأمر (data8) وعلى ذلك ستكون واختصارا op code والبايت الأخرى هي المعلومة (data8) . وعلى ذلك ستكون الصورة العامة للشفرة الثنائية لهذا الأمر كالتالى :

00ddd110 data8

حيث ddd تستبدل بشفرة المسجل أو الذاكرة M المراد وضع المعلومة فيها .

#### مثال 4-3

MVI B,53H .1

الشفرة الثنائية هي: 00000110

01010011

الشفرة الستعشرية هي: 06H 53H

هذا الأمر سيضع المعلومة الفورية أو الثابت 53H في المسجل B . نفضك أن نسمى مثل هذه المعلومة بالمعلومة الفورية لأنها ليس لها مصدرا وإنما مصدره هو المستخدم نفسه ، ومن هنا كان الحرف I في الأمر وهو اختصارا لكلمة I immediate أو فورى وسوف يصادفنا أوامر أخرى تحتوى الحرف I وكلها تتعامل مع معلومات فورية أو ثوابت بهذا الشكل .

من الممكن تحميل معلومة فورية Immediate في مكان ما في الذاكرة بحيث يكون عنوان هذا المكان في المسجلين HL كالتالي:

MVI M, data8 .2

والشفرة الثنائية لهذا الأمر ستكون كالتالى :

00110110 data8

المثال التالي يعتبر تدريبا جيدا على الأمرين MOV و MVI

#### مثال 4-4

المطلوب تحميل المسجلات H, E, D, C, B, A بالمعلومات الفورية التالية: 06,05,04,03,02,01 المحتويات كما هو مبين في شكل (4-2i) بحيث أن محتويات المسجل A تذهب المحتويات كما هو مبين في شكل (4-2i) بحيث أن محتويات المسجل B ومحتويات B تذهب إلى المسجل B ومحتويات B تذهب الله المسجل A دون فقد محتويات أي مسجل . شكل (4-2-2i) يوضح المسجل B إلى المسجل A دون فقد محتويات أي مسجل . شكل (4-2-2i) يوضح مخطط السير لهذا البرنامج ، وشكل (4-3i) يبين الشفرات الأسممبلي والثنائية والستعشرية للبرنامج . لتنفيذ هذا البرنامج يمكنك أن تفتح ال B عند العنوان وأما إذا كان الميكروكومبيوتر الذي تستخدمه به الأسمبلر الخصاص بالشريحة وأما إذا كان الميكروكومبيوتر الذي تستخدمه به الأسمبلر الخصاص بالشريحة تفاصيل عملية إدخال البرنامج على الجهاز لأنها تختلف على حسب الإمكانيات تفاصيل عملية إدخال البرنامج على الجهاز لأنها تختلف على حسب الإمكانيات ومن شخص لأخر . بعد الانتهاء من إدخال البرنامج يمكنك تنفيذه باستخدام الأمر B ومن الأفضل تنفيذه بطريقة الخطوة خطوة حيث يمكنك فسي هذه الحالة متابعة البيانات أثناء انتقالها من مسجل لآخر .

عند استخدام الأمر MOV M,C مثلا لنقل محتويات المسجل C إلى الذاكرة أو الأمر MOV M,C لتحميل المعلومة الفورية 33 في الذاكرة ذكرنا أن عنوان الذاكرة الذي سيتم التعامل معه يكون دائما في المسجلين HL. السؤال الآن كيف

نضع هذا العنوان في المسجلين H و L؟ الإجابة عن هذا السؤال توجد في الأمر LXI .



# <u>1-2-4 الأمر LXI</u> الصورة العامة لهذا الأمر هي:

LXI rp,data16
rp خروج مسجلات data16

الشفرة الثنائية للأمر كالتالى:

00rp0001

البايث ذات القيمة الصغرى من المعلومة data16 البايت ذات القيمة العظمى من المعلومة data16

حيث يقوم هذا الأمر بتحميل زوج المسجلات الذى توضع شفرته بدلا من rp (في البايت الأولى للأمر) بالمعلومة الفورية data16 أي المكونة من 16 بت والتي توضع في الإثنين بايت التاليتين . حرف I الموجود في صورة الأمر له

نفس الدلالة التي عرفناها مسبقا والتي تعنى فورى أي Immediate للحيظ أن المعلومة مكونة من 16 بت وشفرة الأمر op code ستكون بايت واحدة ، اذليك فإن هذا الأمر يتكون دائما من ثلاث بايتات كما سنرى في الأمثلة . لاحظ أيضا أن هناك أربعة أزواج من المسجلات فقط يمكن استخدامها مع هذا الأمر وهي الإزواج SP, HL, DE, BC, BC والتي سبق أن ذكرنا شفراتها في جدول 1-2 لذلك فإن البايت ذات القيمة العظمي من المعلومة ال10 بت تذهب دائما إلى المسجل ذي القيمة العظمي من الزوج وهو المسجل 10 أو أو ألم أو ألم أو ألم ألموا ألموا

| العناوين | شفرات           | شفرات    | شفرات<br>ستعشرية |  |
|----------|-----------------|----------|------------------|--|
|          | شفرات<br>أسمبلي | ثنائية   | ستعشرية          |  |
| E000     | MVI A,01        | 00111110 | 3E               |  |
| E001     |                 | 00000001 | 01               |  |
| E002     | MVI B,02        | 00000110 | 06               |  |
| E003     |                 | 00000010 | 02               |  |
| E004     | MVI C,03        | 00001110 | 0E               |  |
| E005     |                 | 00000011 | 03               |  |
| E006     | MVI D,04        | 00010110 | 16               |  |
| E007     |                 | 00000100 | 04               |  |
| E008     | MVI E,05        | 00011110 | 1E               |  |
| E009     |                 | 00000101 | 05               |  |
| E00A     | MVI H,06        | 00100110 | 26               |  |
| E00B     |                 | 00000110 | 06               |  |
| E00C     | MOV L,A         | 01101111 | 6F               |  |
| E00D     | MOV A,H         | 01111100 | 7C               |  |
| E00E     | MOV H,E         | 01100011 | 63               |  |
| E00F     | MOV E,D         | 01011010 | 5A               |  |
| E010     | MOV D,C         | 01010001 | 51               |  |
| E011     | MOV C,B         | 01001000 | 48               |  |
| E012     |                 |          | 45               |  |

شكل (4-3) برنامج الإزاحة الدورية

#### مثال 4-5

1. شفرة الأسمبلي 1. مفرة الأسمبلي 00100001 الشفرة الثنائية 00111010 00101100 21 الشفرة الستعشرية 3A 2C

يقوم هذا الأمر بتحميل زوج المسجلات HL بالمعلومة الفوريـــة 2C3A بحيــث ستذهب البايت ذات القيمة العظمى وهى 2C إلى المسجل H والبايت ذات القيمـة الصغرى وهى 3A إلى المسجل A بنفــس الطريقــة يمكــن تحميــل الأزواج الأخرى من المسجلات . كما رأينا فإن هذا الأمر مهم جدا عنـــد التعــامل مـع الذاكرة حيث عنوان المكان المراد التعامل معه يوضع فـــى المســجلين H و L باستخدام هذا الأمر .

#### مثال 4-6

حمل مكان الذاكرة E100 بالمعلومة 66H . أحد الطرق لكى يتم ذلك هى أن نقوم بتحميل العنوان E100 فى زوج المسجلات HL ثم نستخدم الأمر E000 E001, E002 LXI HE100

E003, E004 MVI M,66H

لاحظ أننا استخدمنا هنا الشفرات الأسمبلي فقط ولاحظ أيضا أن الأمر الكالا الله الله الله الكالم الكالم

إن الطريقة السابقة في التعامل مع الذاكرة والتي تستخدم زوج المسجلات HL كوسيط يحمل العنوان المراد التعامل معه تعتبر بل وتسمى بالطريقة غير المباشرة في التعامل مع الذاكرة حيث أن المعالج قبل أن يذهب إلى الذاكرة سواء للقراءة أو الكتابة لابد وأن يمر أو لا على زوج المسجلات HL ليعسرف منهما العنوان الذي سيذهب إليه . إن ذلك تماما مثلما أنك تقول لصديقك محمد يساخى يامحمد وأنت مسافر إلى الرياض خذ هذه الرسالة وأعطها لأخى أحمد ولكنى لا أعرف عنوانه فرجاء أن تذهب إلى أخى الأكبر محمود وهو يسكن معنسا هنا فتعرف منه عنوان أحمد قبل أن تسافر إلى الرياض . صديقك محمد فسى هذا المثال يمثل المعالج الذي سيقوم بالتنفيذ وأما أخسوك الأكبر محمود فيمثل المسجلين عندهما عنوان أخيك أحمد الذي يمثل بايت الذاكرة المسراد التعامل معها . نعيد التأكيد هنا أن زوج المسجلات HL فقط هما اللذان يحتويسان عنوان المراد التعامل معه في مثل هذه الأوامر .

هناك طريقة أخرى التعامل مع الذاكرة وهى الطريقة المباشرة حيث يحتوى الأمر نفسه على عنوان مكان الذاكرة المراد التعامل معه ، وإن ذلك مثلما تقول لصديقك محمد يأخى يا محمد خذ هذه الرسالة وأنت مسافر إلى الرياض وأعطها إلى أخى أحمد ولا تنسى أن عنوان أخى أحمد مكتوب على الرسالة هذه الموة . الأمران الذان يقومان بهذه المهمة من قائمة أوامر الشريحة 8085 هما الأمران STA و LDA كما يلى :

### 4-2-4 الأمران STA و LDA

الأمر STA يعنى خزن محتويات المركم STore Accumulator والأمسر الثاني يعنى حمل المركم LoaD Accumulator والصورة العامة للأمرين هي:

STA addr

محتويات المسجل A ->العنوان (addr)

LDA addr

A محتويات العنوان (addr) المسجل

والصورة الستعشرية الأمر STA هي:

32

البايت ذات القيمة الصغرى من العنوان Addr البايت ذات القيمة العظمى من العنوان Addr

والصورة الستعشرية للأمر LDA هي:

3 4

البايت ذات القيمة الصغرى من العنوان Addr البايت ذات القيمة العظمى من العنوان Addr

الأمر الأول STA سيقوم يتخزين محتويات مسجل التراكم A في مكان الذاكسرة الذي عنوانه في (الإثنين بايت) التاليتين لشفرة الأمر نفسه وأما الأمر LDA فإنه يقوم بتحميل مسجل التراكم A بمحتويات مكان الذاكرة الذي عنوانه في (الإثنيين بايت) التاليتين لشفرة الأمرين لفسه . هناك ملاحظتان هامتان على هذين الأمرين : الأولى هي أن هنين الأمرين لا يتعاملان إلا مع مسجل التراكم A فقط ، فأنت مثلا إن أردت أن تخزن محتويات المسجل B في أي مكان في الذاكسرة بهذه الطريقة المباشرة فلابد وأن تتقل محتويات المسجل B إلى المسجل وليكن C مثلا تستخدم الأمر STA ، وكذلك الحال إن أردت أن تحمل أي مسجل وليكن C مثلا بمحتويات أي مكان في الذاكرة بالطريقة المباشرة فعليك باستخدام الأمسر LDA مثلا الذي يضع محتويات الذاكرة في مسجل التراكم ثم تقوم أنت بنقل هذه المحتويات من مسجل التراكم إلى أي مسجل آخر وليكن C كما ذكرنا . الملاحظة الثانيسة هي أنه طالما أن هذين الأمرين يحتويان على عنوان فلابد وأن يتكون كل منهما من ثلاث بايتات ، واحدة هي شفرة الأمر ، أي 32 في حالة الأمسر STA و STA و

فى حالة الأمر LDA وأما (الإثنين بايت) الأخرى فتحتوى العنوان المراد التعامل معه كما فى الصورة العامة للأمرين . تذكر أن أى عنوان يتكون دائما من 16 بت أى 2 بايت .

#### <u>مثال 4-7</u>

E000 E001 E002 STA E100 E003 E004 E005 LDA E101

الأمر الأول سيخزن محتويات المسجل A في المكان E100 في الذاكرة والأمر الثانى سيحمل المسجل A بمحتويات المكان E101 من الذاكرة ، لاحظ أنه فك ذاكرة البرنامج كل أمر من الأمرين يشغل ثلاث بايتات .

القرار باستخدام أى واحدة من الطريقتين (المباشرة أو غير المباشرة) في عملية البرمجة يتوقف على التطبيق الذي يستخدم فيه هذا البرنامج وسنرجىء هذا الموضوع قليلا إلى أن ندرس بعض الأوامر الأخرى وعندها سنوضح أن هناك برامج يفضل فيها استخدام الطريقة المباشرة وأخرى لابد فيها من استخدام الطريقة المباشرة وأخرى لابد فيها من استخدام الطريقة عبر المباشرة.

### 5-2-4 الأمران LHLD و SHLD

معناهما load H,L Direct أى حمل المسجلين H, L مباشرة ، و load H,L Direct أى خزن المسجلين H, L مباشرة وكلا الأمرين كما نرى تأثيره عكسس الآخر . الصورة العامة لهذين الأمرين هي :

LHLD addr I← (addr ) محتویات ، H← (addr+1) محتویات SHLD addr (addr )← L محتویات ، (addr+1)← H

الصورة الستعشرية للأمر LHLD هي :

2A

البايت ذات القيمة الصغرى للعنوان addr البايت ذات القيمة العظمى للعنوان addr

الصورة الستعشرية للأمر SHLD هي :

22

البايت ذات القيمة الصغرى للعنوان addr البايت ذات القيمة العظمى للعنوان addr

addr بتحميل المسجلين H و H بتحميل المسجلين العنوان العنوان العنوان LHLD و الذي يليه في الذاكرة ، أي أن محتويات العنوان addr تذهب السيحل H . الأمر SHLD ومحتويات العنوان الذي يليه H . H . الأمر

يقوم بالعملية العكسية للأمر LHLD حيث يقوم بتخزين محتويات المسجلين H و L في العنوان addr و الذي يليه بحيث تذهب محتويات المسجل L السي addr العنوان addr ومحتويات المسجل H إلى العنوان L

#### مثال 4–8

I. افترض الوضع التالي في المسجلين HL ومكاني الذاكرة E100 و E101:

| Н  | L  |
|----|----|
| 89 | 76 |

| E100 | FF |
|------|----|
| E101 | FF |

بعد تتفيذ الأمر SHLD E100 سيصبح الوضع كما يلى:

| Н  | L  |  |  |
|----|----|--|--|
| 89 | 76 |  |  |

| E100 | 76 |
|------|----|
| E101 | 89 |

افترض الوضع التالى في المسجلين HL ومكانى الذاكرة E100 و E101 :

| Н  | L  |  |  |
|----|----|--|--|
| 89 | 76 |  |  |

| E100 | 3A |
|------|----|
| E101 | B5 |

بعد تنفيذ الأمر LHLD E100 سيصبح الوضع كالتالى:

| Н  | L  |
|----|----|
| B5 | 3A |

| E100 | 3A |
|------|----|
| E101 | B5 |

إلى هنا سنكتفى بهذه المجموعة من أوامر الانتقال ولمزيد من المعرف...ة بباقى أوامر الإنتقال انظر الأشكال الموجودة فى آخر هذا الفصل والتى تحتوى على نبذة مختصرة عن كل أمر.

### 4-3 تـمــاريــن

اكتب برنامجا يضع الأزقام الستعشرية 1 إلى A في الذاكـــرة E201 إلـــي
 E20A.

- 2. اكتب برنامجا يضع الرقم 77 فى المسجل D والرقم B4 فى المسجل C شهر المتبدال محتويات كل من المسجلين ، أى أن محتويات المسجل C تذهب إلى المسجل D ومحتويات المسجل C ون أن تفقد أيا من محتويات المسجل Swapping بمعنى استبدال أو مقايضة .
  3. نفذ عملية الاستبدال السابقة فى المسألة رقم 2 ولكن هذه المرة على محتويات البايت E100 و البايت .
- 4. اكتب برنامجا للإزاحة الدورانية كالموجود في مثال 4-4 ولكن هذه المسرة على محتويات الذاكرة E100 و E101 و E100 و E100 و E100 و E100 ملاحظات: يجب عمل مخطط سير لكل برنامج ثم تترجم هذه الخريط قبل السي برنامج بلغة الأسمبلي مع الشفرات الثنائية والستعشرية وتحديد العناوين لكل أمو وذاكرة البرنامج وذاكرة البيانات لكل برنامج، أي أن كل برنامج يحسل بنفس طريقة حل المثال رقم 4-4 وحتى تكتمل الفائدة بالذات عند هذا المستوى يجسب أن تحمل هذه البرامج بالشفرات الثنائية أو لا ثم الشفرات الستعشرية ثم شهدات الأسمبلي.

4-4 مجموعة أوامر الحساب Arithmatic Instructions

| ADD                           |
|-------------------------------|
| SUB                           |
| · ADI                         |
| SUI                           |
| ADC                           |
| SBB                           |
| INR                           |
| INX                           |
| DCR                           |
| DCX                           |
| شكل (4-4) مجموعة أوامر الحساب |

سندرس في هذا الجزء بعض الأوامر التي تقوم بإجراء العمليات الحسابية الأولية وهي الجمع والطرح . كما علمنا من قبل فإن مسجل التراكم لابد وأن يكون طرفا في أي عملية من هذه العمليات كما أن نتيجة هذه العملية سواء كانت جمعا أو طرحا تكون دائما موجودة في مسجل التراكم A . هناك أيضا خاصية مهمة

في هذه المجموعة من الأوامر غير موجودة في الأوامر الأخرى وهي أن أوامو الحساب (ومثلها أيضا أوامر المنطق) عندما يتم تتفيذ أي أمر منها فيان جميع الأعلام الموجودة في مسجل الحالة SR تتأثر بنتيجة هذه العملية الحسابية أو المنطقية . راجع مسجل الحالة ومحتوياته ومتى يكون أي عليم من الأعلام المنطقية . يساوي صفرا أو واحدا وذلك في الفصل الثاني حيث أن جميع الأعلام الموجودة في مسجل الحالة في المعالج 8085 هي نفسها تماما التي شرحت في هذا الجزء في مسجل الحالة التي سنستعين بها في هذا الجزء سنكتفي باستخدام شفرات الأسمبلي جميع الأمثلة التي سنستعين بها في هذا الجزء سنكتفي باستخدام شفرات الأسمبلي فقط على أساس أنه تم التدريب الكافي على الشفرات الثنائية والستعشرية مع مجموعة أو امر الانتقال ومن يريد الاستزادة في التدريب يمكنه الإستمرار في ذلك مستعينا بالشفرات الستعشرية التي سنذكرها مع الصورة العامة لكهل أمر وكذلك في الأشكال الموجودة في نهاية هذا الفصل .

#### 4-4-1 الأمران ADD و SUB

حيث ADD بمعنى إجمع و SUB هي أختصار كلمة SUBtract بمعنى اطرح، والصورة العامة لأمر الجمع ADD هي :

ADD reg

 $A \leftarrow A + reg$ 

حيث سيقوم هذا الأمر بجمع محتويات المسجل reg أو مكان الذاكرة M الدى عنوانه في المسجلين M على محتويات مسجل التراكم M وستوضع نتيجة الجمع في المسجل M مع التأثير على جميع الأعلام . الشفرة الثنائية العامة لهذا الأمر هي M مع التأثير على بين M بشفرة المسجل الذي سيتم جمعه مصع مسلم التراكم . كمثال على ذلك الأمر M M مستكون شفرته الثنائية هي M وهي M وشفرته الستعشرية هي M حيث استبدلت M بشفرة المسجل M وهي M ومن

الصورة العامة لأمر الطرح SUB هي:

SUB reg

 $A \leftarrow A - reg$ 

يقوم هذا الأمر بطرح محتويات المسجل reg أو مكان الذاكرة M الذي عنوانه في المسجلين HL من محتويات مسجل التراكم وسوف توضع نتيجة الطـــرح فــى مسجل التراكم مع التأثير على جميع الأعلام . الشفرة الثنائية العامة لهذا الأمــر هي xxx بشفرة المسجل المطلوب طرح محتوياته مــن مسجل التراكم . كمثال على ذلك الأمر SUB M ستكون شــفرته الثنائيــة هــى مسجل التراكم . كمثال على ذلك الأمر SUB M ستكون شـفرته الثنائيــة هــى 10010110 وشفرته الستعشرية هي 96H .

#### مثال 4-9

افترض المحتويات التالية للمسجلين A و B :



بعد تنفيذ الأمر ADD B ستصبح المحتويات كالتالى:



ولكى نرى كيف تتأثر الأعلام بنتيجة هذه العملية سنجرى عملية الجمع على الشفر ات الثنائية لكل من الرقمين كالتالى:



الأن افترض أننا نفذنا أمر الطرح SUB B على المحتويات الأولى للمسجلين أى A=AAH و B=A5H فإنه بعد تنفيذ هذا الأمر ستصبح محتويات المسجلين كالتالى:

| В  | A  |  |  |
|----|----|--|--|
| A5 | 05 |  |  |

ولكى نرى كيف تمت عملية الطرح وكيف تأثرت الأعلام سنجرى عملية الطرح على الشفرات الثنائية لمحتويات للمسجلين A و B . كما نعلم فإن عملية الطرح الثنائى يتم تحويلها إلى عملية جمع حيث سنجمع محتويات المسجل A مع المتمم الثنائى لمحتويات المسجل B (انظر الملحق الأول في نهايسة الكتاب لمراجعة عمليات الجمع والطرح الثنائى). المتمم الثنائى لمحتويات المسجل B(10100101) هو 10110110 وبذلك تصبح عملية الطرح عملية جمع كالتالى:

A = 10101010 + 01011011 المتمم الثنائي لمحتويات المسجل B - 00000101

بالنظر لهذه النتيجة ستكون الأعلام كالتالى:

- طالما أن البت الأولى على الأقل لا تساوى صفرا فالنتيجة لا تساوى صفرا ويكون علم الصفر يساوى صفرا أى ZF=0.
- تحتوى النتيجة على عدد زوجى من الوحايد (اثنين) ، بذلك سيكون علم الباريتي يساوى واحدا أي PF=1 .
- هناك حمل من البت الثالثة إلى البت الرابعة لذلك فعلم الحمل النصفى يكون واحدا HCF=1 .
- أخر بت (رقم 7) تساوى صفرا لذلك فالنتيجة موجبة وعلم الإشارة يكون دائما مساويا لمحتويات آخر بت إذن SF=0 .
- المفروض أنه في عملية الطرح يهمنا أن نعرف إذا كان هناك استلاف أم لا لأنه في عملية الطرح لن يكون هناك حمل . بما أن عملية الطرح قد حولت إلى عملية جمع لذلك فإنه إذا كان هناك حمل في عملية الجمع فإن ذلك يعنى أنه لن يكون هناك استلاف في عملية الطرح ويكون العلم 0=CF وهي الحالة التي نحن بصددها الآن والعكس صحيح إذا لم يكن هناك حمل في عملية الجمع .

### 4-4-2 الأمران ADI و SUI

الأمر الأول اختصارا ل Add Immediate أى اجمع المعلومة الفورية أو الشابت ، والأمر الثانى Subtract Immediate والتى تعنى أيضا اطرح المعلومة الفورية أو الثابت ، وقد أشرنا سابقا إلى أن الحرف I فى أى أمر يعنى التعامل مع معلومة فورية أو ثابت يعطى فى الأمر نفسه . الصورة العامة للأمر ADI هى :

ADI data8  $A \leftarrow A + data8$ 

والشفرة الستعشرية العامة لهذا الأمر هي :

C6 data8 حيث يقوم هذا الأمر بجمع محتويات البايت الثانية في الأمر مع محتويات مسجل التراكم A ويضع النتيجة في المسجل A وعلى ضوء هذه النتيجة تتاثر جميع الإعلام . لاحظ أن هذا الأمر يتكون دائما من اثنين بايت ، واحدة هي شفرة الأمر والثانية هي البايت أو الرقم المطلوب جمعه مع المسجل A .

الصورة العامة للأمر SUI هي:

SUI data8
A← A − data8

والشفرة الستعشرية لهذا الأمر هي:

D6 data8

حيث يقوم هذا الأمر بطرح محتويات البايت الثانية في الأمر من محتويات مسجل التراكم A ويضع النتيجة في المسجل A وعلى ضوء هذه النتيجة تتاثر جميع الأعلام . لاحظ أن هذا الأمر أيضا يتكون من اثنين بايت .

#### مثال 4-10

المطلوب هو جمع الثابت أو المعلومة الفورية 05 على محتويات المسجلات C, B . شكل (C-5) يبين مخطط السير وشفرات الأسسمبلى لهذا البرنامج ملاحظة مهمة في هذا البرنامج هي أنه لكى نجمع الثابت مع أى مسلح فإننا نحضر أو ننقل محتويات المسجل أو لا إلى مسجل التراكم C ثم نجمع الثابت مع المسجل C وبالطبع فإن النتيجة تكون في المسجل C فنقوم بنقلها إلى المسلح الأخر ثانية. وهل يوجد حل آخر C!

### 3-4-4 الأمران ADC وSBB

الأمر الأول يعنى Add with Carry أى اجمـع مـع الحمـل ، والثـاني يعنـي ADC أي اطرح مع الاستلاف والصورة العامة للأمــر DC هي :

ADC reg

 $A \leftarrow A + CY + reg$ 

حيث يقوم هذا الأمر بجمع محتويات المسجل reg مع محتويات علم الحمل CY (لاحظ أن علم الحمل يكون إما صفرا أو واحد) مع محتويات مسجل التراكم A والنتيجة توضع بالطبع في المسجل A. الشفرة الثنائية لهذا الأمرهي:

10001xxx

حيث تستبدل ال xxx بشفرة المسجل المراد التعامل معه .

#### الصورة العامة للأمر SBB هي:

SBB reg  $A \leftarrow A - CY - reg$ 

حيث يطرح هذا الأمر من محتويات مسجل التراكم A محتويات المسجل reg ومحتويات علم الحمل CY مع ملاحظة أن المسجل A يكون هو المطروح منهدا دائما في جميع أوامر الطرح . الشفرة الثنائية لهذا الأمر هي :

10011xxx

حيث تستبدل ال xxx بشفرة المسجل المراد التعامل معه .



#### مثال 4-11

المطلوب جمع الرقمين H23F9 و PA35H و وضع نتيجة الجمع في أماكن الذاكرة E100 و E101 و E101 . In E102 و E101 و E103 و E103 . In E103 و E103 و E105 . In E104 . In E105 و E105 و E105 . In E105 . I

قبل أن نترك الأمر ADC يجب أن نفهم جيدا متى يكون من الضرورى استخدام الأمر ADC ومتى يكون من الضرورى عدم استخدامه ؟ فمثلا في المثال السابق (ADC) كان من الضرورى عدم استخدام الأمر ADC في عملية الجمع الأولى (E+C) ولكن يجب استخدم الأمر ADD خوفا من أن يكون علم الحمل CY به واحد من أي عملية سابقة ونحن لا ندرى فيجمع مع عملية الجمع الأولى وتكون النتيجة خاطئة . أما في عملية الجمع الثانية (D+B+CY) فإنه لابد من استخدام الأمر ADC لأننا نريد أن نأخذ قيمة علم الحمل ADC في الاعتبار .

#### 4-4-4 الأمران INR و DCR

الأمر الأول يعنى Increment أى زد المحتويات بمقدار واحد ، و Decrement أى انقص المحتويات بمقدار واحد ، والصورة العامة للأمر INR هى :

INR reg

 $reg \leftarrow 1 + reg$ 

حيث يقوم هذا الأمر بجمع واحد على محتويات المسجل reg أو مكان الذاكرة M الذي عنوانه في HL . الصورة الثنائية لهذا الأمر هي :

00xxx100

حيث xxx تستبدل بشفرة المسجل المراد التعامل معه . الصورة العامة للأمر DCR هي :

DCR reg reg − 1

M أمر بطرح واحد من محتويات المسجل reg أو مكان الذاكرة M أو مكان الذاكرة الذي عنوانه في HL . الصورة الثنائية لهذا الأمر هي :

00xxx101 حيث xxx تستبدل بشفرة المسجل المراد التعامل معه .



#### DCX و INX الأمران 5-4-4

الأمران INX و DCX هما مرادفان للأمرين INR و DCR ولكنهما يستخدمان مع أزواج مسجلات ، فالأمر INX يجمع واحسدا على محتويسات زوج من المسجلات والصورة العامة الأسمبلي والثنائية له هي :

INX rp 00xx0011

rp←-1 + rp

حيث xx تستبدل بشفرة زوج المسجلات المراد التعامل معه . وأما الأمرر DCX فإنه يطرح واحدا من محتويات زوج من المسجلات وصورته العامة (الأسمبلى والثنائية) هي :

DCX rp 00xx1011 rp← rp - 1

حيث تستبدل xx بشفرة زوج المسجلات المراد التعامل معه .

#### مثال 4-12

المطلوب تخزين الأرقام 05, 04, 03, 02, 01 في أماكن الذاكرة التسبى عناوينها المطلوب تخزين الأرقام E105, E104, E103, E102, E101 على التوالى . شكل (-7) يبيسن خريطة التدفق والبرنامج لحل هذه المسألة . لاحظ استخدام الأمر INR لزيادة واحد على محتويات المسجل A والأمر INX لزيادة واحد على محتويات زوج المسبجلات محتويات المشال . نلاحظ من شكل (-7) أننا لكى نخزن خمسة أرقسام فسى الذاكرة كتبنا برنامجا مكونا من ثمانية عشرة بايت (-7) أننا كى نخزن خمسة أرقسام في لو أننا نريد تخزين ألف رقم أو أكثر ، كم ستشغل من ذاكرة للبرنسامج...! هل هناك من حل لتخفيض عدد أو امر مثل هذه البرامج ؟ إن الحل لذلك هو استخدام أو امر القفز والحلقات وهو موضوع الجزء القادم بعد أن نعرض بعض التملين كتطبيق على أو امر الحساب .

#### 5-4 تسماريان

اكتب برنامجا يجمع محتويات أماكن الذاكرة E101, E102, E101 ثم يضيع E10E, E10D, E10C,E10B, E10A ثم يضيع E10E, E10D, E114, E113, E112, E111, E110.

2. أعد البرنامج السابق مستخدما الطرح بدلا من الجمع .

- 3. اكتب برنامجا يجمع الرقم F3A56BH مع الرقم 78B6A9H ويضع النتيجـــة
   في بايتات الذاكرة E103, E102, E101, E100
  - 4. أعد البرنامج السابق مستخدما الطرح بدلا من الجمع. .



# 6-4 مجموعة أو امر القفز Jump Instructions

القاعدة العامة أن المعالج يقوم بتنفيذ البرنامج حسب ترتيب الأوامر الموجودة فيه من أول البرنامج إلى نهايته ، ولقد كنا حريصين في جميع الأمثلة السابقة على من أول البرنامج إلى نهايته ، ولكن هناك بعض التطبيقات التي تتطلب الخروج على هذه القاعدة كأن يطلب منك مثلا تتفيذ عملية معينة عدد معين من المرات أو عدد لا نهائي من المرات . فعندما يكون المعالج مثلا مراقبا لدرجة الحرارة في عملية صناعية معينة فإن عليه أن يقرأ درجة الحرارة ويقارنها بدرجة حرارة مخزنة في الذاكرة كمرجع ، وإذا زادت الحرارة عن حد معين يقوم المعالج بضرب جرس إنذار مثلا وإذا نقصت عن حد معين يشغل سخان لزيادتها ، مثل هذا البرنامج سيكون عبارة عن مجموعة من الأوامر التي تنفذ إلى مالانهاية طالما أن المعالج يراقب درجة الحرارة .

لقد أتاح المعالج هذه العملية بتوفير بعض الأوامر التي تمكنك كمبرمج من القفر : بعملية التنفيذ من مكان لآخر خلال البرنامج . هناك نوعان من القفز :

### 1-6-4 القفز غير المشروط Unconditional jump

عند تنفيذ أى عملية قفز غير مشروط ينتقل المعالج بعملية التنفيذ إلى المكان المجان المجديد دون أى قيد أو شرط، وهناك أمر واحد فقط من أوامر المعالج 8085 يقوم بهذه العملية، والصورة العامة لهذا الأمر هى:

JMP addr

حيث إنه عند تتفيذ هذا الأمر يوضع العنوان addr الذى سيتم القفز إليه فى عداد البرنامج فيصبح الأمر الموجود عند هذا العنوان هو الأمر الذى عليه الدور فل التنفيذ . لاحظ أن هذا الأمر يتكون من ثلاث بايتات واحدة هلي شفرة الأمر واثنتان للعنوان addr الذى سيتم القفز إليه .

إن القفز باستخدام الأمر JMP addr قد يكون إلى الأمام في البرنامج وقد يكون إلى الأمام في البرنامج وقد يكون إلى الخلف . إذا كان القفز إلى الأمام سينتج عن ذلك وجود جزء من البرنامج لن ينفذ على الإطلاق وهو الجزء الذي بين أمر القفز JMP والأمر الذي سيتم القفز إليه . أما إذا كان القفز إلى الخلف فإنه سينتج عن ذلك ما يسمى بالحلقة الملانهائية Infinite loop والتي سوف يستمر المعالج في تنفيذها إلى مالانهاية . شكل (8-4) ببين مخطط السير لعملية القفز غير المشروط الأمامي والخلفي .

### 2-6-4 القفر المشروط Conditional jump

كما يوحى الإسم فإنه في هذا النوع من القفر لن يتم القفر إلا إذا تحقق شرط معين أما إذا لم يتحقق الشرط فإن البرنامج ينفذ في النتابع الطبيعي حيث سينفذ

الأمر الذى بعد أمر القفز مباشرة . إن شروط القفز توضع دائما على الأعلام التى فى مسجل الحالة ، فيمكنك مثلا أن تجعل القفز مشروطا بأن تكون النتيجة سالبة ، وهكذا ، حيث أن هناك خمسة أعلام واحد منها وهو علم الحمل النصفى HC لا يستخدم كشرط فى عمليات القفز فإنه يتبقى أربعة أعلام يمكن أن تستخدم فى ثمانية من أو امر القفن المشروط كالتالى :

اقفز إذا كانت النتيجة صفرا JZ addr اقفز إذا كانت النتيجة ليست صفرا JNZ addr اقفز إذا كانت النتيجة سالبة JM addr اقفز إذا كانت النتيجة موجبة JP addr اقفز إذا كان هناك حمل JC addr اقفز إذا لم يكن هناك حمل JNC addr اقفز إذا كانت الباريتي فردية JPO addr اقفز إذا كانت الباريتي زوجية JPE addr



لاحظ أن عدد هذه الأوامر ثمانية ، إثنان منها لكل علم من الأعلام الأربعة تمثل جميع الحالات التي يمكن أن يكون فيها هذا العلم (صفرا أو واحدا) . إن جميسع

هذه الأوامر لابد وأن تكون ثلاث بايتات ، واحدة هـى شـفرة الأمـر op code واثنتان للعنوان الذى سيتم القفز إليه إذا تحقق الشرط . لاحظ أن النتيجـة التـى نعنيها فى الأوامر السابقة هى آخر نتيجة تأثرت بها الأعلام ، ولذلك فإنه قبـل أن نكتب أى أمر من أوامر القفز غير المشروط يجب أن ندرس جيدا هــل الأمـر السابق لأمر القفز المشروط يؤثر على الأعلام أم لا كما سـيتضح مـن المثـال التالى:

#### مثال 4-13

اكتب برنامجا يقرأ محتويات بايت الذاكرة E100 باستمرار (إلى مالانهاية) شميختبر هذه المحتويات بحيث إذا كانت صغرا يضع 1 في المسجل B وإذا كانت صغرا يضع 2 في نفسس المسجل B وإذا كانت موجبة يضع 4 في نفسس المسجل B . B شكل (B-9) يبين خريطة التدفق والبرنامج لهذا المثال . البرنامج الموجود في شكل (B-9) يعتبر تدريبا على معظم أفكار الحلقات ، ففيه الحلقيات اللانهائية شكل (B-9) يعتبر تدريبا على معظم أفكار الحلقات ، ففيه الحلقيات اللانهائية عن الأمر B addr . B كما أن فيه القفز المشروط B على الأمام في البرنامج ، والقفز إلى الخلف أيضا . لذلك يجب دراسة هذا البرنامج بدقة وإمعان .

هناك أو امر أخرى يتسبب عنها قفز بعملية تنفيذ البرنامج إلى أماكن أخرى وهي أو امر القفز إلى البرامج الفرعية والعودة منها وسوف نرجىء الدراسة التفصيلية للبرامج الفرعية إلى فصل آخر خاص بذلك .

# 4-7 مهمة أخرى للأسمبلر

المهمة الوحيدة التى عرفناها حتى الآن للأسمبار هى مهمة تحويل الشفرات الحرفية (الأسمبلى) إلى شفرات ثنائية أو لغة الماكينة ، ولكن لحسن الحظ فإن الأسمبار قد تم تزويده ببعض المهام الأخرى التى تريح المبرمج إلى درجة كبيرة والتى سنتعرف على واحدة منها فى هذا الجزء . ينظر أى أسمبار إلى الأمر الذى تكتبه له على أنه مكون من أجزاء أربعة كالموضحة فى شكل (4-10) والتى سندرسها بالترتيب فيما يلى :

#### 1-7-4

لقد درسنا الكثير من أوامر لغة الأسمبلي والتي سنلخصها كلها في شكل واحد وفي ترتيب أبجدي في آخر هذا الفصل إن شاء الله . من هذه الأوامر برتيب أبجدي في آخر هذا الفصل إن شاء الله . من هذه الأوامر المبد وأن يكون له معاملات ADD, JMP, وهذه المعاملات هي المسجلات أو أماكن الذاكرة التي سوف يؤثر عليها الأمر ،

فمثلا الأمر ADD C معاملاته هي المسجلين A, B والأمر MOV A,B معاملاته هي المسجل C والأمر ADD M معاملاته هي بايت الذاكرة التي عنوانها في المسجلين HL .... و هكذا . هناك أو امر قليلة ليست لها معاملات على الإطلاق ومنها الأمر NO Operation والذي معناه لا تعمل شيئا NO Operation كما أن عدد المعاملات في أي أمر لا يزيد عن اثنين بأي حال . إن الأمر يجب أن يفصل عن معاملاته بمسافة واحدة على الأقل وإن زاد عدد المسافات عن واحدة فلن يضر ذلك في شيء حيث أن الأسمبلر يهملها ، أما إذا لم توجد مسافة واحدة على الأقل بين الأمر ومعاملاته فإن الأسمبلر سيعطى خطأ على ذلك ولن يقبل منك هذا الأمر . إذا كان الأمر له معاملان كالأمر A,B فإن الأسمبلر يعطى رسالة خطأ على يفصل بينهما بفاصلة (,) وإذا لم يحدث ذلك فإن الأسمبلر يعطى رسالة خطأ على ذلك .



 Label:
 Command Operand I Idad
 ; Comment ; Comment ; Comment ; Edward ; Comment ; Edward ; Edwa

## 2-7-4 التعليق Comment

حتى تجعل برنامجك مفهوما ومن السهل قراءته وتتبعه بالنسبة للآخريسن فإنسه يجب عليك أن تكتب بعض التعليقات البسيطة بجانب كل أمر . لذلك فإن الأسمبلر يعطيك فرصة أن تكتب أى شيء تريده في نهاية الأمر على أن تفصل بين الأمو والتعليق بفاصلة منقوطة يفهم منها الأسمبلر أن كل المكتوب بعدها يعتبر تعليق ولا يدخل ضمن الأمر . إذا كان التعليق الذي ستكتبه سيأخذ أكثر من خط واحد فإن كل خط يجب أن يبدأ بفاصلة منقوطة . المثال التالي سيوضح أهمية كتابة التعليق في نهاية الأمر .

#### مثال 4. 14

; Multiplication of two numbers

E000 E001 MVI A,00; Put 0 into A, Clean accumulator

E002 ADD B ; Addition of A and B, result goes to A

E003 DCR C ; Decrement C by 1

E004 E005 E006 JNZ E002 ;Go to add B to itself one more time

;as long as C not equal to 0

E007 E008 E009 STA E100 ; store result in location E100

هذا البرنامج يضرب الرقم الموجود في المسجل B في الرقصم الموجود في المسجل C ويضع النتيجة في بايت الذاكرة رقم D000. بما أنه ليس هناك أمصر من أو امر الشريحة 8085 يقوم بإجراء عملية الضرب لذلك كان لابد أن نكتب هذا البرنامج لإجراء عملية الضرب عن طريق تكرار الجمع حيث يجمع البرنامج محتويات المسجل D1 مع نفسه عدد من المرات يساوى الرقم الموجود في المسجل D2 مستجد أن التعليقات المكتوبة بجانب الأو امر تدل على ذلك . التعليق الموجود في المسجل في السطر الأول مثلا يقول "ضع صفرا في D4 من تنظيف المركم " وهذا ضرورى حتى لا نجمع أي رقم قد يكون في المسجل D5 قبل البدء في عملية جمع المسجل D6 مع نفسه . التعليق في السطر الثاني يقول "جمع D8 من نفسه . التعليق في السطر الثاني يقول "جمع D8 من نفسه . التعليق في السطر الثاني يقول "جمع D8 من نفسه . التعليق في السطر الثاني يقول "جمع D8 من نفسه . التعليق في السطر الثاني يقول "جمع D8 من نفسه . التعليق في السطر الثاني يقول "جمع D8 من نفسه . التعليق في السطر الثاني يقول "جمع D8 من نفسه . التعليق في المسجل D8 من نفسه . التعليق في المسجل D9 من المسجل D9 من نفسه . التعليق في المسجل D9 من نفسه . التعليق في المسجل D9 من المسجل D9 من نفسه . التعليق في المسجل D9 من المسجل D9 من المسجل D9 من نفسه . التعليق في المسجل D9 من المسجل D9 من نفسه . التعليق في المسجل D9 من المسطل D9 من المسجل D9 من المسجل D9 من المسجل D9 من المسجل D9 من المسجل

أن هذا الأمر هو بداية حلقة يتم القفز إليها من السطر الرابع وفي المرة الأولىي من دخول هذه الحلقة سيجمع المعالج المسجل A=0 مع محتويات المسجل B من دخول هذه الحلقة سيجمع المعالج المسجل القيص محتويات C بمقدار فيصبح A=B. التعليق في السطر الرابع يقول "ارجع لجمع المسجل B مع نفسه مرة أخرى طالما أن C لا يساوي صفرا ، النتيجة في A." التعليق في السطر السادس وهو الخامس يقول "خزن النتيجة في البايت E100". التعليق في السطر السادس وهو الخط المنقط تم وضعه فقط للدلالة على نهاية البرنامج وهذا أحيانا يكون مهما جدا في عملية تنظيم كتابة البرنامج خاصة إذا كان البرنامج مكونا من أكثر من جزء حيث يمكن الفصل بين الأجزاء المختلفة عن طريق مثل هذه الخطوط التي يعرفها الأسمبلر على أنها تعليقات ، بالطبع يجب أن تكون التعليقات باللغة الإنجليزية ، إلا إذا كان محرر الكلمات الذي تستخدمه في كتابة البرنامج سيسمح لك باستخدام اللغة العربية في التعليقات .

#### 1-7-4 العلامة Label

في جميع البرامج التي كتبناها حتى الأن كنا حريصين تمامــا علـى أن نكتـب عناوين البايتات التي يشغلها أي أمر من أوامر البرنامج ، وكانت هدده العملية ضرورية بالذات عند التعامل مع أوامر القفز التي نحتاج فيها لمعرف ـــة عنوان الأمر الذي سنقفز إليه مثل الأمر الرابع في المثال السابق (مثال ضرب الرقمين 4-4) وهو JNZ E002 ، فلو لا أننا كنا نكتب عناوين البايتات التي عندها الأوامر لما حددنا أن القفز يجب أن يكون إلى الأمر الثاني وهـو E002 ADD B . فـي الحقيقة إن مهمة تتبع العناوين لجميع أوامر البرنامج تعتبر مهمة صعبة للمبرمج وبالذات إذا كان البرنامج يحتوى على الكثير من أوامر القفز ، وتعتبر مهمة سهلة للأسمبلر يستطيع القيام بها في نفس الوقت . فطالما أن الأسمبلر يعرف جيدا عدد الباينات التي يتكون منها كل أمر فلم لا يتولى هو عملية العنونة لأوامر البرنامج على أن يعطيه المبرمج فقط عنوان أول أمر في البرنامج ، وما على المبرمج في هذه الحالة إلا الكتابة فقط بالشفرات الأسمبلى ، هنا يبرز سيؤال مهم : كيف سنحدد للأسمبلر الأوامر التي من الممكن أن يتم القفز إليها ؟ إن ذلك يتم عن طريق العلامات Labels التي نضعها قبل الأمر المراد القفز إليه على أن نستخدم نفس العلامة في أمر القفز نفسه ، إننا سنعيد كتابة البرنامج الموجود في المتـال 4-14 مرة أخرى دون استخدام عناوين للأوامر وباستخدام العلامات كمــا فـي المثال 4-15 .

#### مثال 4-15

MVI A,00 ; Put 0 into accumulator

HERE: ADD B ; A+B into A

DCR C ; Decrement C by 1

JNZ HERE ; Jump to add B to itself one more

; time as long as C not equal to 0

STA E100 ; Store result in E100

لاحظ أننا وضعنا العلامة وهي كلمة :HERE كعلامة عند الأمر الذي سيتم القفر الدي وهو الأمر الثاني في البرنامج السابق ، واستخدمنا نفس العلامة HERE في الأمر JNZ HERE في الأمر JNZ HERE كي يتم القفز إلى الأمر رقم 2 . من البديهي أنسه لابسد وأن يكون هناك تطابق تام بين العلامة في الأمر الذي سيتم القفز إليه والعلامة في أمر القفز نفسه بحيث إذا لم يوجد هذا التطابق فإن الأسمبلر سيعطى خطأ ، أيضا لابد وأن تنتهي العلامة الموجودة في أول الأمر الذي سيتم القفز إليه بالحرف (:) ليميز بها الأسمبلر بين نهاية العلامة وبداية الأمر . كما أن عدد أحرف العلامسة يجب ألا يزيد عن ثمانية أحرف لا تبدأ برقم . .

البرنامج الموجود في المثال 4-14 مكتوب في الذاكرة ابتداء من البايت E000 بسبب نريد نقل البرنامج بحيث يبدأ من البايت E050 بسدلا افترض مثلا أننا لأي سبب نريد نقل البرنامج بحيث يبدأ من البايت E050 بسدلا من E000 . في هذه الحالة لابد وأن نعيد قحص البرنامج بدقة ونغسير العناوين الموجودة في جميع أو امر القفز في البرنامج ، فمثلا الأمر E002 ، وهكذا تخيل لو أن البرنامج به العديد من أو امر القفز فإنه لا شك ستكون عملية إعادة عنونة الأو امر من الصعوبة بمكان وبالذات في البرامج الطويلة . إن استخدام العلامات الأو امر القفز حتى لو تغير مكان البرنامج لأنك تعطى الأسسمبلر عنوان بداية أو امر القفز حتى لو تغير مكان البرنامج لأنك تعطى الأسسمبلر عنوان بداية البرنامج فقط وهو ينسب جميع العلامات إلى عنوان البداية وهذه في الحقيقة فائدة عنوم وفر ها الأسمبلر المبرمج . لذلك فإن جميع البرامج التي سنعرضها فيما بعد سنكتبها باستخدام لغة الأسمبلي والعلامات دون الحرص على كتابة عناوين بعد سنكتبها باستخدام لغة الأسمبلي والعلامات دون الحرص على كتابة عناوين الأوامر لأننا بذلك نكون قد عبرنا مرحلة لا بأس بها في لغة الأسمبلي .

# 8-4 أو امر الإدخال والإخراج Input Output instructions

إلى الآن رأينا كيف نبرمج شريحة المعالج وكيف نحرك المعلومات داخلها مــن مسجل إلى مسجل الحي مسجل الله الذاكرة أو العكس ولكن لم نعرف حتى الآن كيف نظهر معلومة على شاشة عرض مثلا أيا كان نوع هذه الشاشــة، أو

كيف ندخل معلومة إلى المعالج من خلال لوحة مفاتيح على سبيل المثال الشاشة العرض ولوحة المفاتيح يعتبران مثالان من ضمن العديد من الأمثلة التحتاج لعمليات الإخراج والإدخال . فمثلا حينما يستخدم المعالج في التحكم في أي متغير في أي عملية صناعية وليكن مثلا درجة الحرارة فإنه لابد من إدخال درجة الحرارة إلى المعالج بعد تهيئتها ووضعها في الصورة المناسبة لذلك ، وكذلك إذا أراد المعالج رفع درجة الحرارة أو ضرب جرس إنذار فإنه لابد وأن يخرج إشارة معينة تؤخذ وتهيأ في الصورة المناسبة للجهاز الذي ستذهب إليه سواء كان سخانا أو جرسا أو غيره . جميع عمليات الإدخال والإخراج نتم من خلل ما يسمى ببوابات الإدخال والإخراج والتعامل مع هذه البوابات دائما ينقسم إلى قسمين : قسم خاص بالبناء الإلكتروني لهذه البوابات وكيفية توصيلها مع المعالج وهذا القسم سندرسه بالتفصيل في فصل قادم إن شاء الله ، والقسم الأخر هو كيفية برمجة المعالج للتعامل مع هذه البوابات وهو موضوع دراستنا في هذا الجزء برمجة المعالج للتعامل مع هذه البوابات وهو موضوع دراستنا في هذا الجزء حيث سندرس الأوامر الخاصة بهذه البوابات وهو موضوع دراستنا في هذا الجزء عيث القارىء لديه على الأقل بوابة إدخال واحدة وبوابة إخراج واحدة موصلان القارىء لديه على الأقل بوابة إدخال واحدة وبوابة إخراج واحدة موصلان على الميكروكومبيوتر الذي يتدرب عليه ويكتب عليه برامجه .

### 4-8-1 أمر الادخال IN وأمر الإخراج OUT

وهما اختصار لكلمتى Input يعنى أدخل و Output يعنى أخرج والصورة العامة للأمر IN هي :

IN no.

البوابة رقم .no ->المسجل A

حيث سبقوم هذا الأمر بإدخال المعلومة الموجودة على بوابة الإدخال والتى رقمها من الأمر نفسه إلى مسجل التراكم A. هذا الأمر يتكون من اثنين بايت واحدة هي شفرة الأمر IN والثانية هي رقم البوابة المراد التعامل معها ، ولذلك فإنسه يمكن التعامل مع E = 256 بوابة إدخال تبدأ من البوابة رقم E + 00H الستعشرية في جدول الأوامر في نهاية هذا الفصل. الصورة العامة لأمر الإخراج E + OUT هي :

OUT no.

المسجل A البواية رقم no.

حيث سيقوم هذا الأمر بإخراج المعلومة الموجودة في مسجل التراكم A إلى بوابة الإخراج التي رقمها . no . هذا الأمر يتكون من اثنين بايت واحدة هي شفرة الأمر OUT والثانية هي رقم البوابة المراد التعامل معها ، ولذلك فإنه يمكن التعامل معها 25 = 250 بوابة إخراج تبدأ أيضا من البوابة رقم HOO إلى البوابة رقم FFH. انظر شفرة الأمر OUT الستعشرية في جدول الأو امر في نهاية هذا الفصل .

لاحظ أن كلا من بوابة الإدخال وبوابة الإخراج تتكون من 8 بتات مثلها في ذلك مثل أي مسجل يتكون من 8 بتات ولذلك فإن أكبر رقم يمكن أن يكون علي أي بوابة هو الرقم 255 . تذكر أيضا أن أي تعامل مع أي بوابة باستخدام هذين الأمرين لابد وأن يكون من خلال المركم A ، فإذا أردت أن تخسرج محتويات المسجل C مثلا إلى بوابة الإخراج رقم 05 فإنه لابد وأن تتقل هذه المحتويات إلى المسجل A أو لا ثم تتفذ أمر الإخراج كما يلى :

MOV A,C ; A ولي C انقل محتويات OUT 05 ; 05 مقرم الإخراج رقم أخرج على بوابة الإخراج رقم 50 ;

بعد تتغیذ الأمرین السابقین ستری محتویات المسجل C علی بوابة الإخراج رقم 05 . أما إذا أردنا أن ندخل محتویات بوابة الإدخال رقم 00 ونخزنها فی بیات الذاکرة رقم E100 فإننا ننفذ الأمرین التالیین علی سبیل المثال:

أدخل محتويات بوابة الإدخال رقم 00 إلى المركم: 1N 00

خزن محتويات المركم في البايت E100 ; E100

بعد تنفيذ هذين الأمرين فإنه إذا كانت محتويات بوابة الإدخال رقم 00 تسلوى 55 مثلا فإن هذا الرقم (55) ستجده في البايت E100 .

#### مثال 4–16

إفترض أن لدينا خط إنتاج في أحد المصانع تعبر عليه المنتجات وفي أثناء العبور فإن كل منتج يقطع خلية ضوئية فتعطى نبضة كهربية على خرجها . خرج هذه الخلية موصل على البت رقم 0 في بوابة الإدخال رقم 0 المطلوب هو كتابة برنامج يعد هذه المنتجات ويخرج العدد على بوابة الإخراج رقم 0 أيضا . شكل (1-4) يبين رسما توضيحيا لهذه العملية وشكل (1-4) يبين مخطط السير والبرنامج لهذا المثال .



لاحظ وجود الأمر CPI وهو أحد أو امر الحساب التي لهم نشرحها وتركناها للقارىء لمراجعتها من قوائم الأو امر في نهاية الفصل ، ولقد استخدم هذا الأمر

لمقارنة محتويات المسجل A القادمة من بوابة الإدخال بالقيمة 00 أو لا ، وطالما أن هذه المحتويات تساوى 00 فإن ذلك يعنى عدم مرور أى منتسج على خط الإنتاج ويقوم المعالج بتكرار عملية القراءة حيث يقفز إلى HERE1 كما فى البرنامج .



عندما يمر أى منتج ستكون محتويات بوابة الإدخال مختلفة عن الصفر ولن يرجع المعالج إلى العلامة :HERE1 ثانية ولكنه سيزيد محتويات المسحل B بمقدار

واحد حيث B تعتبر عدادا للمنتجات المارة على الخط ، ثم بعد ذلك سيقوم المعالج بقراءة بوابة الإدخال مرة أخرى للتأكد من أن المنتج قد مر من على الخط وذلك بمقارنة محتويات بوابة الإدخال بالقيمة 01 وطالما أنها تساوى 01 يقفز إلى العلامة :HERE2 حيث لا يعمل شيئا سوى قراءة البوابة . عندما تنزل البوابة إلى 00 مرة أخرى فإن ذلك يدل على أن المنتج قد مر على الخط فيقوم المعالج بإخراج قيمة العداد B على بوابة الإخراج ويذهب إلى العلامة :HERE1 مرة أخرى لمواصلة البرنامج .

# 9-4 مجموعة أوامر المنطق Logic Instruction Set

العمليات المنطقية التي يستطيع المعالج 8085 القيام بها هـــى العمليات XOR, OR, AND وسنكتفى هنا بعرض الصورة العامة لهذه الأوامر على أن NOT, OR, AND يقوم القارىء بمراجعة هذه الأوامر في القوائم الموجودة في آخر الفصل لمعرفة الشفرات الستعشرية والزمن الذي يأخذه كل أمر لكي يتم تتفيذه . كما ذكرنا سلبقا فإن العمليات المنطقية مثلها مثل العمليات الحسابية لابد وأن يكون المركم طرف فيها كما أن النتيجة لابد وأن توضع في المركم أيضا . جميع العمليات المنطقية تؤثر على الأعلام ، انظر قوائم الأوامر في آخر الفصل لترى ذلك ولترى متى تكون هذه الأوامر مكونة من بايت واحدة ومتى تكون مكونة من 2 بايت .

ANA reg

A مسجل A مسجل AND reg

حيث سيقوم المعالج بإجراء عملية AND علي محتويات المسجل reg مع محتويات مسجل reg مع محتويات مسجل التراكم A ونتيجة العملية توضع في المركم . بنفسس الطريقة يمكننا كتابة الصورة العامة للأمرين OR و XOR كما يلي :

ORA reg

XRA reg

حيث سيقوم الأمر الأول بإجراء عملية OR على محتويات المسجل reg مع محتويات المسجل A و معتويات المسجل A و يضع النتيجة في المسجل A و أما الأمر الثاني فسيجرى عملية XOR على محتويات المسجل reg مع محتويات المركم ويضع النتيجة في المركم . جميع العمليات المنطقية الثلاث السابقة يمكن أن تجرى على معلومة فورية أو ثابت وفي هذه الحالة فإن الصورة العامة لهذه الأو إمر ستكون:

ANI data8

ORI data8

XRI data8

حيث data8 هو الثابت أو المعلومة الفورية المراد إجراء العملية المنطقية عليها . لاحظ أن هذه الأوامر في هذه الحالة سيكون كل منها مكونا من 2 بايت ، واحدة هي شفرة الأمر والثانية هي قيمة الثابت data8 .

#### مثال 4-17

افترض أن محتويات المسجل A تساوى FFH ومحتويات المسجل B تساوى FOH و FOH و FOH محلوب إجراء عمليات FOH و FOH FOH

A=11111111 B=11110000

النتيجة بعد إجراء الأمر ANA B هي: 11110000

أى أن محتويات المركم سنتغير إلى FOH . جميع الأعلام سنتأثر بهذه النتيجة ملا عدا علمى الحمل والحمل النصفى حيث يكونان صفرا دائما فى جميع العمليات المنطقية لأنه لا يحدث لا حمل و لا حمل نصفى مع أى عملية منطقية .

ثانيا: عملية OR

A=11111111 B=11110000

النتيجة بعد إجراء الأمر ORAB هي : 11111111

أى أن محتويات المركم ستظل FFH وستتأثر الأعلام بنفس الطريقة التي ذكرناها مع عملية AND .

ثالثا : عملية XOR

A=11111111 B=11110000

النتيجة بعد إجراء الأمر XRAB هي: 00001111

أى أن محتويات المركم ستصبح OFH وستتأثر جميع الأعلام بنفس الطريقة السابقة .

بذلك نكون قد أنهينا دراسة المجموعات الأساسية في أوامر المعالج 8085 علي اننا لم نذكر بالطبع جميع الأوامر داخل كل مجموعة ولكننا بذلك نكون قد عرفيا الغالبية العظمى من الأوامر وما تبقى منها فمن السهل معرفته من جداول الأوامر الموجودة في آخر هذا الفصل كما أن هناك أبواب خاصة ستتعرض لمجموعيات معينة من الأوامر مثل الأوامر الخاصة بالبرامج الفرعية والأوامير الخاصة بالمقاطعة حيث سيفرد فصل خاص لكل منها إن شاء الله نتيجة لأهميتها .

# 10-4 كيفية الإتصال بالذاكرة Memory addressing

أى معلومة من حيث المكان إما أن تكون موجودة داخل المعالج نفسة في أى مسجل من مسجلاته وفي هذه الحالة فإنه يمكن التعامل معها بسهولة وتحريكها من مكان لآخر داخل المعالج في زمن أقل ، وإما أن تكون موجودة في الذاكرة ويريد المعالج قراءتها ، أى إحضارها من الذاكرة ووضعها في أى مسجل مسن مسجلاته ، أو كتابتها أى نقلها إلى الذاكرة ، وذلك يتطلب من المعالج أن يحدد عنوان المكان أو البايت في الذاكرة التي سنتم معها عملية القراءة أو الكتابة . طريقة تحديد عنوان البايت من الذاكرة المراد التعامل معها هي المقصود دراسته في هذا الجزء . يجب أن نتذكر جيدا أن جميع شرائح المعالجات التي نتعامل معها إلى الآن لها مسار عناوين به 16 بتا ولذلك فإننا عندما سنكتب أي عنوان في النظام الستعشري فلابد أن نكتبه من 4 خانات حيث كل خانه في النظام المتتشري مقال 4 بتات في النظام المتعشري وغالبا نضيع الحرف H الدلالة على أن الرقم مكتوبا في النظام الستعشري وغالبا نضيعا الحرف الدلالة على أن الرقم مكتوبا في النظام الستعشري .

هناك طريقتان يحدد بهما المعالج 8085 عنوان المكان أو البايت في الذاكرة المراد التعامل معه وسنبين هاتين الطريقتين فيما يلي:

#### 1-10-4 الطريقة المباشرة Direct method

في هذه الطريقة فإن الأمر نفسه يحتوى عنوان البايت المراد التعامل معها ، ولذلك فإن كل الأوامر التي تقع تحت هذا الصنف تتكون من ترلث بايتات ، واحدة من هذه البايتات هي شفرة الأمر operation code واختصارا تكتبب opec واحدة من هذه البايت التالية هي عنوان المكان في الذاكرة المراد التعامل معه . تذكر أن البايت تتكون من 8 بتات وأنه دائما تكون البايت الأولى من بايتات العنوان هي البايت ذات القيمة الصغرى Low significant byte . بالنسبة للمعالج العنوان هي البايت ذات القيمة الصغرى STA addr كامثلة على الأوامر التي تتعامل STA addr و LDA addr كامثلة على الأوامر التي تتعامل بهذه الطريقة. كما رأينا سابقا فإن الأمر addr يقوم بتحميل المسجل A (المركم) بمحتويات المكان في الذاكرة الذي عنوانه موجود في الأمر نفسه وقد رمزنا له بالرمز addr . أما الأمر STA addr فإنه يفعل العكس حيث يقوم بتخزين محتويات المسجل A في المكان الذي عنوانه ما عنوانه عنوانه مكان في الذاكرة .

#### 2-10-4 الطريقة غير المباشرة Indirect method

فى هذه الطريقة يوضع عنوان البايت المراد التعامل معها فى المسجلين H و H بحيث يحتوى المسجل H على البايت ذات القيمة العظمى من العنوان ويحتوى

المسجل I على البايت ذات القيمة الصغرى منه . مثل هذه الأوامر تتكون دائما من بايت واحدة حيث يرمز لهذا المكان في الذاكرة بالرمز M وتأخذ الشفرة 110 كما رأينا من خلال تعاملنا مع الأوامر سابقا . فمثلا الأمو MOV A, معناه انقل محتويات بايت الذاكرة التي عنوانها في زوج المسجلات H السي مسجل التراكم .

السؤال الذي يتبادر إلى الذهن هنا أى الطريقتين يفضل في الاستخدام ، الطريقة المباشرة أم غير المباشرة ؟ الإجابة عن هذا السؤال تتوقف على البرنامج أو على المشكلة التي نبرمجها . فإذا كان البرنامج يتعامل مع الذاكرة باستمرار وبالذات المشكلة التي نبرمجها . فإذا كان البرنامج يتعامل مع الذاكرة باستمرار وبالذات تكون الأفضل لأنها ستوفر الكثير من طول البرنامج لأن المسجلين HL في هذه الحالة سيكونان عبارة عن مؤشر إلى بايت الذاكرة التي تستخدمها وكلما أردت التعامل مع بايت جديدة تزيد محتويات المسجلين HL بواحد كما رأينا في المثال التعامل مع بايت جديدة تزيد محتويات المسجلين HL بواحد كما رأينا في المثال التعامل مع الذاكرة لمرة واحدة فإنه اليس هناك أى داع لاستخدام الطريقة غير المباشرة ولكن يفضل في هذه الحالة الطريقة المباشرة . الأشكال التالية تحتوى مجموعة أوامر المعالج 8085 مقسمة أو لا إلى مجموعات كما أشرنا سابقا بحيث يحتوى كل شكل الأوامر الخاصة بمجموعة معينة والشفرة الستعشرية وعدد نبضات التزامن التي يحتاجها كل أمر لكي يتم إحضاره من الذاكرة وتنفيذه . شكل (4-18) يبين قائمة أوامر الشريحة 8085 مرتبة ترتيبا الذاكرة وتنفيذه . شكل و فيفة كل أمر وكذلك الأعلام التي نتأثر بكل أمر .

| MOV        | A               | В  | C   | D  | E   | H  | L   | M  |
|------------|-----------------|----|-----|----|-----|----|-----|----|
| ,A         | 71 <sup>F</sup> | 47 | 4F  | 57 | 5F  | 67 | 6F  | 77 |
| ,В         | 78              | 40 | 48  | 50 | 58  | 60 | 68  | 70 |
| , <u>C</u> | 79              | 41 | 49  | 51 | 59  | 61 | 69  | 71 |
| ,D         | 7A              | 42 | 4A  | 52 | 5Λ  | 62 | 6A  | 72 |
| ,E         | 7B              | 43 | 4B  | 53 | 513 | 63 | 613 | 73 |
| H.         | 7C              | 44 | 4C  | 54 | 5C  | 64 | 6C  | 74 |
| .L         | 7D              | 45 | 4D  | 55 | 5D  | 65 | 61) | 75 |
| ,M         | 7E              | 46 | 41: | 56 | 5E  | 66 | 6E  |    |

| MVI | Α    | В    | C    | D    | E    | Н    | L    | M    |
|-----|------|------|------|------|------|------|------|------|
|     | 3Exx | 06xx | 0Exx | 16xx | IExx | 26xx | 2Exx | 36xx |

| LDA (13) | STA (13) |
|----------|----------|
| 3Axxxx   | 32xxxx   |

| LDAX B (7) | LDAX D (7) | STAX B (7) | STAX D (7) |
|------------|------------|------------|------------|
| 0A         | 1A         | 02         | 12         |

| IN (10) | OUT (10) | LHLD (16) | SHLD (16) |
|---------|----------|-----------|-----------|
| DBxx    | D3xx     | 2Axxxx    | 22xxxx    |

| XCHG (4) | XTHL (16) | SPHL (6) |
|----------|-----------|----------|
| EB       | E3        | F9       |

|     | LXI (10) | POP (10) | PUSH (10) |
|-----|----------|----------|-----------|
| В   | 01xxxx · | CI       | C5        |
| D   | Hxxxx    | DI       | D5        |
| Н   | 21xxxx   | El       | E5        |
| SP  | · 31xxxx |          |           |
| PSW |          | Fl       | F5        |

<sup>•</sup> جميع الأوامر التي على الصورة MOV M,reg و MOV rcg,M تاخذ 7 نبضات تزامن والأوامر التي على الصورة MOV reg,reg تأخذ 4 نبضات تزامن .

XX تعنى معلومة 8 بتات (data8) و XXXX تعنى علوان أو معلومة 16 بتا

<sup>•</sup> جميع الأوامر التي على الصورة MVI rcg.xx تأخذ 7 نبضات تزامن حتى يتـــم إحضار هـا وتلفيذهـا والأمر MVI M.xx يأخذ 10 نبضات.

الأرقام التي بين القوسين للأوامر الأخرى تدل على عدد النبضات التي ياخذها الأمر.
 شكل (4-13) مجموعة أو امر الانتقال للمعالج 8085

|   | INR | DCR | ADD | SUB | ADC | SBB |
|---|-----|-----|-----|-----|-----|-----|
| A | 3C  | 3D  | 87  | 97  | 8F  | 9F  |
| В | ()4 | 05  | 80  | 90  | 88  | 98  |
| C | 0C  | 0D  | 81  | 91  | 89  | 99  |
| D | 14  | 15  | 82  | 92  | 8A  | 9A  |
| E | 1C  | ID  | 83  | 93  | 8B  | 9B  |
| Н | 24  | 25  | 84  | 94  | 8C  | 9C  |
| L | 2C  | 2D  | 85  | 95  | 8D  | 9D  |
| M | 34  | 35  | 86  | 96  | 8E  | 9E  |

|    | INX | DCX | DAD |
|----|-----|-----|-----|
| В  | 03  | 0B  | 09  |
| D  | 13  | 1B  | 19  |
| Н  | 23  | 2B  | 29  |
| SP | 33  | 3B  | 39  |

| ADI(7) | SUI(7) | ACI(7) | SBI(7) | DAA(4) |
|--------|--------|--------|--------|--------|
| C6xx   | D6xx   | CExx   | DExx   | 27     |

- الأوامر SBB M . ADC M . SUB M . ADD M كلها تأخذ 7 نبضات لكي يتم إحضار ها وتتفيذها .
  - الأمران INR M DCR M تأخذ 10 نبضات.
- جميع أوامر الحساب الأخرى تحتاج إلى 4 نبضات .
   الأرقام التي بين القوسين لبعض الأوامر تدل على عدد النبضات اللازمة لإحضار وتنفيذ هذا الأمر. أ

شكل (4-14) مجموعة أوامر الحساب

|     | ANA | ORA        | XRA | СМР        |
|-----|-----|------------|-----|------------|
| A   | A7  | B7         | AF  | BF         |
| В   | B0  | A0         | A8  | В8         |
| С   | Al  | B1         | A9  | <b>B</b> 9 |
| D   | A2  | B2         | AA  | BA         |
| E   | A3  | B3         | AB  | BB         |
| Н . | A4  | B4         | AC  | BC         |
| L   | A5  | <b>B</b> 5 | AD  | BD         |
| M   | A6  | B6         | AE  | BE         |

| ANI  | ORI  | XRI  | CPI  | CMA |
|------|------|------|------|-----|
| Ебхх | F6xx | EExx | FExx | 2F  |

جميع أوامر المنطق تأخذ 4 نبضات ما عدا الأوامر التي تتعامل مع ذاكرة M والأوامر
 ANI ORI XRI CPI فتأخذ7 نبضات لكي يتم إحضارها وتتفيذها.

شكل (4-15) مجموعة أوامر المنطق

| JMP  | JC   | JNC  | JZ   | JNZ  | JM   | JP   | JPE  | JPO  |
|------|------|------|------|------|------|------|------|------|
| C3   | DA   | D2   | CA   | C2   | FΛ   | F2   | EA   | E2   |
| ZZZZ | XXXX |

• هذه الأوامر إذا تم لها القفر تأخذ 10 نبضات وإذا لم يتم القفر تأخذ 7 نبضات لكي يتم المحدارها وتنفيذها .

| CALL | CC   | CNC  | CZ   | CNZ  | CM   | CP   | CPE  | CP<br>O |
|------|------|------|------|------|------|------|------|---------|
| CD   | DC   | D4   | CC   | C4   | FC   | F4   | EC   | E4      |
| XXXX    |

هذه الأوامر تأخذ 18 نبضة إذا تم لها القفز وإذا لم يتم القفز تأخذ 9 نبضات .

| RET | RC | RNC | RZ | RNZ | RM | RP | RPE | RPO |
|-----|----|-----|----|-----|----|----|-----|-----|
| C9  | D8 | D0  | C8 | C0  | F8 | F0 | E8  | E0  |

هذه الأوامر تأخذ 12 نبضة إذا تم القفز و 6 إذا لم يتم ما عدا الأمر RET فإنسه ياخذ 10 نضات.

| RST 7 | RST 6 | RST 5 | RST 4 | RST 3 | RST 2      | RST 1 | RST 0 |
|-------|-------|-------|-------|-------|------------|-------|-------|
| FF    | F7    | EF    | E7    | DF    | <b>D</b> 7 | CF    | C7    |

هذه الأوامر تأخذ 12 نبضة لكي يتم إحضارها وتتفيذها .

| PCHL |  |
|------|--|
| E9   |  |

• هذا الأمر يحتاج إلى 6 نبضات لكي يتم إحضاره وتتفيذه .

شكل (4-16) مجموعة أوامر القفز

| RLC | RRC | RAL | RAR | CMC | STC | EI | DI | HLT | NOP |
|-----|-----|-----|-----|-----|-----|----|----|-----|-----|
| 07  | OF  | 17  | 1F  | 3F  | 37  | FB | F3 | 76  | 00  |

| RIM | SIM |
|-----|-----|
| 20  | 30  |

جميع هذه الأوامر تحتاج إلى 4 نبضات لكى يتم إحضارها وتنفيذها .

شكل (4-17) أو امر أخرى

| الأسميلي                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | الشفرة                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | الأعلام               | وظيفة الأمسر                                       |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|----------------------------------------------------|
| بيست.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | المتأثرة              | J                                                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                       |                                                    |
| ACI const                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 11001110<br>data8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ZSPCYHC               | $A \leftarrow A + A$                               |
| ADD reg                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 10000sss                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ZSPCYHC               | مسجل + A → A                                       |
| ADC reg                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 10001sss                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ZSPCYHC               | A← A + الحمل + A + مسجل + علم الحمل                |
| ADI const .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 11000110<br>data8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ZSPCYHC               | ثابت + A <u>→ →</u> A                              |
| ANA reg                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 10100sss                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ZSP 0 0               | $A \longleftarrow A AND$ مسجل                      |
| ANI const                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 11100110<br>data8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ZSP 0 0               | A ← A AND ثابت                                     |
| the space of the by the strate of the strate |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Burney Branch Company |                                                    |
| CALL addr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | CD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                       | نداء غير مشروط على برنامج فرعى                     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | addr16 .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                       |                                                    |
| CC addr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | DC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                       | نداء برنامج فرعى مشروط بعلم                        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | addr16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                       | 1= لمحلا                                           |
| CM addr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | FC<br>addr16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                       | نداء برنامج فرعى مشروط بنتيجة سالبة                |
| CMA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 2F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                       | اعكس محتويات المسجل A                              |
| CMC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 3F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                       | اعكس علم الحمل                                     |
| reg                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 10111sss                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ZSPCYHC               | قارن مسجل مع مسجل A. اطرح ( reg                    |
| CMP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | •                     | <ul> <li>A) المسجل A لا يتأثر بالنتيجة.</li> </ul> |
| CNC addr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | D4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                       | نداء برنامج فرعى مشروط بعلم الحمل-                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | addr16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                       | 0                                                  |
| CNZ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | C4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                       | نداء برنامج فرعى مشروط بعلم                        |
| addr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | addr16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                       | الصفر=0                                            |
| CP addr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | F4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                       | نداء برنامج فرعى مشروط بنتيجة                      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | addr16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                       | موجبة                                              |
| CPE addr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | EC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                       | نداء برنامج فرعي مشروط بباريتي                     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | addr16 .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                       | زوجية                                              |
| CPI const                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | FE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ZSPCYHC               | مقارنة , (ثابت - A ) والمسجل A لا                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | data8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                       | يتاثر                                              |
| CPO addr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | E4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                       | نداء برنامج فرعى مشروط بباريتي                     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | addr16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                       | فردية                                              |
| CZ addr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | CC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                       | نداء برنامج فرعي مشروط بعلم                        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | addr16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                       | الصفر -1                                           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 100 May 100 Ma |                       |                                                    |
| DAA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | . 27                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ZSPCYHC               | حول المركم إلى النظام العشرى                       |

|              | T            | 1                 | T                                       |
|--------------|--------------|-------------------|-----------------------------------------|
| DAD =        | 00m 1001     | CY                |                                         |
| DAD rp       | 00rp1001     | ZSPCYHC           | HL←HL + rp                              |
| DCR reg      | 00ddd101     | ZSPCYHC           | انقص محتويات المسجل reg بمقدار 1        |
| DCX rp       | 00rp1011     |                   | انقص محتويات المسجلين rp بمقدار 1       |
| DI           | F3           |                   | اهمل المقاطعة                           |
|              | :: ". "      |                   |                                         |
| EI           | FB           |                   | اسمح بالمقاطعة                          |
| 120          |              |                   |                                         |
| HLT          | 76           |                   | أوقف تنفيذ البرنامج                     |
|              |              | 1. 1. 1. 1. 1. 1. |                                         |
| IN no.       | DB           |                   | اقرأ بوابة الإدخال رقم .no              |
|              | Port no.     |                   | , , , , , , , , , , , , , , , , , , , , |
| INR reg      | 00ddd100     | ZSPCYIIC          | اجمع 1 على محتويات المسجل reg           |
| INX rp       | 00rp0011     |                   | اجمع 1 على محتويات المسجلين rp          |
|              |              |                   |                                         |
| JC addr      | DA           |                   | قفز مشروط بعلم الحمل = 1                |
|              | addr16       |                   |                                         |
| JM addr      | FA           |                   | قفز مشروط بعلم الإشارة = 1              |
| 7.00         | addr16       |                   |                                         |
| JMP addr     | C3<br>addr16 |                   | قفز غير مشروط                           |
| INC -11      |              |                   | 0 1 11 1 5 100                          |
| JNC addr     | D2<br>addr16 |                   | قفز مشروط بعلم الحمل = ()               |
| JNZ addr     | C2           |                   | قفز مشروط بعلم الصفر = 0                |
| JINZ, addi   | addr16       |                   | لعر مسروط بعلم الصفر – 0                |
| JP addr      | F2           |                   | قفز مشروط بعلم الإشارة = 0              |
| JI quui      | addr16       |                   | نظر مسروند بعدم ، مساره ن               |
| JPE addr     | EA           |                   | قفز مشروط بباريتي زوجية                 |
|              | addr16       |                   | 2. 23 G 23 33 3                         |
| JPO addr     | E2           |                   | قفز مشروط بباریتی فردیة                 |
|              | addr16       |                   |                                         |
| JZ addr      | CA           |                   | قفز مشروط بعلم الصفر = 1                |
|              | addr16       |                   | ·                                       |
|              |              |                   |                                         |
| LDA addr     | 3A           |                   | محتويات عنوان —→المسجلA                 |
|              | addr16       |                   |                                         |
| LDAX rp      | 00rp1010     |                   | محتويات العنوان الموجود في الزوج        |
|              | ·            |                   | BC أو DE تتقل المعمجل A                 |
| LHLD addr    | 2A           |                   | محتويات العنوان addr والذي يليه         |
|              | addr16       |                   | → المسجلين HL                           |
| LXI rp,const | 00rp0001     |                   | ثابت من 16 بت>زوج                       |

|              | data 16           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | المسجلات p                               |
|--------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|
|              |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                          |
| MOVreg1,reg2 | 01dddsss          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | محتویات reg1 ← → reg2                    |
| MVIreg,const | 00ddd110<br>data8 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ثابت من 8 بت —> reg                      |
|              |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                          |
| NOP          | 00                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | لا تعمل شيء                              |
|              |                   | - X - X                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 经主要的概念的证据是实验的                            |
| ORA reg      | 10110sss          | ZSPOO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | OR المسجل reg مع المسجل OR               |
| ORI const    | F6                | ZSPOO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | OR ثابت من 8 بت مع المسجل A              |
|              | data8             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                          |
| OUT no.      | D3                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | المسجل A> بوابة الإخراج                  |
|              | Port no.          | Talk and a second                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | رقم.no                                   |
|              |                   | The state of the s |                                          |
| PCHL         | E9                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | قفز للعنوان الموجود في المسجلين HL       |
| РОР гр       | 11rp0001          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | محتويات قمة المكدسة                      |
| PUSH rp      | 11rp0101          | resingle english                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | محتويات rp   قمة المكدسة                 |
|              |                   | CY                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                          |
| RAL          | 17                | Ci                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | دوران المركم للشمال من خلال علم          |
| RAR          | 1F                | CY                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | الحمل<br>دوران المركم لليمين من خلال علم |
| KAK          | l Ir              | 51                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | الحمل المرحم لليمين من حدث علم           |
| RC           | D8                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | عودة مشروطة بعلم الحمل = 1               |
| RET          | C9                | <u> </u>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | عودة غير مشروطة                          |
| RLC          | 07                | CY                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | دوران المركم للشمال , آخر بت الى         |
| 1            |                   | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | البت الأولى وإلى علم الحمل ولا يذهب      |
|              |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | علم الحمل لأول بت                        |
| RM           | F8                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | عودة مشروطة بنتيجة سالية                 |
| RNC          | D0                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | عودة مشروطة بعلم الحمل = 0               |
| RNZ          | C0                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | عودة مشروطة بعلم الصفر = 0               |
| RP           | F0                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | عودة مشروطة بنتيجة موجبة                 |
| RPE          | E8                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | عودة مشروطة بباريتي زوجية                |
| RRC          | OF                | CY                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | دوران المركم لليمين , أول بــت إلــي     |
|              |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | أخر بت وإلى علم الحمل ولا يذهب علم       |
|              |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | الحمل لأخر بت<br>ابدأ من العنوان صفر     |
| RST          | llmnnlll          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ابدأ من العنوان صفر                      |
| RZ           | C8                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | عودة مشروطة بعلم الصفر = ١               |
| RIM          | 20                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | اقرأ قناع المقاطعة                       |
|              |                   | 1734 AT 17                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                          |

| SBB reg   | 10010sss    | ZSPCYIIC | طرح rcg وعلم الحمل من المسجل A     |
|-----------|-------------|----------|------------------------------------|
| SBI const | DE<br>data? | ZSPCYTIC | اطرح ثابت وعلم الحمل من المسجل A   |
|           | data8       |          |                                    |
| SHLD      | 22          |          | خزن محتويات المسجلين HL في         |
|           |             |          | الذاكرة                            |
| SIM       | 30          |          | ضع قناع المقاطعة                   |
| SPHL      | F9          |          | حمل مؤشر المكدسة من المسجلين HL    |
| STA       | 32          |          | خزن محتويات المركم في العنوان addr |
| add       | addr16      | i        |                                    |
| STAX rp   | 00rp0010    |          | خزن المركم في العنوان الموجود      |
|           |             |          | في المسجلين PC) rp و DE فقط)       |
| STC       | 37          | 1 -      | اجعل علم الحمل = ا                 |
| SUB reg   | 10010sss    | ZSPCYTIC | اطرح المسجل rcg من المسجل          |
| SUI const | D6          | ZSPCYIIC | اطرح ثابت من المسجل A              |
|           | data8       |          |                                    |
|           |             | ·        |                                    |
| XCHG      | EB          |          | بدل محتويات المسجلين DE مع HL      |
| XRA reg   | 10101sss    | ZSPOO    | XOR المسجل rcg مع المركم           |
| XRI const | EE          | ZSPOO    | XOR ثابت مع المركم                 |
|           | data8       |          |                                    |
| XCHG      | EB          |          | بدل محتويات المسجلين HL مع         |
|           |             |          | مؤشر المكدسة                       |

#### ملاحظات:

- reg اختصار لكلمة register وتعنى مسجل 8 بت .
- register pair اختصار لكلمة register pair وتعنى زوجا من المسجلات .
- constant اختصار لكلمة constant وتعنى ثابت أو معلومة فورية وأحيانا يكسون هذا الثابت 8 بتات وأحيانا يكون 16 بتا على حسب الأمر إذا كان يتعامل مع مسجل واحد أو زوج من المسجلات.
  - address اختصار لكلمة address وتعنى عنوانا في الذاكرة ودائما يكون العنوان 16بتا .
    - Z تعنى علم الصفر S
      - تعنى علم الإثبارة
      - العنى علم الباريتى
    - CY تعنى علم الحمل HC
    - تعنى علم الحمل النصفي .
    - شكل (4. 18) أوامر الشريحة 8085 مرتبة أبجديا

#### 11-4 تــمــاريـــن

1. أكمل الجدول التالى الخاص بأوامر الشريحة 8085:



2. ما هي نتيجة تنفيذ البرنامج التالي:

E000 MVI A,05
E002 MOV B,A
E003 MOV C,B
E004 MOV D,C
E005 MOV E,D
E006 MOV L,E
E007 MOV H,L
E008 MOV M,L

- 3. اقرأ البرنامج السابق وأجب عما يلى:
  - محتويات مكان الذاكرة ......
  - محتويات مكان الذاكرة .....=E001
  - محتويات مكان الذاكرة .....=0505

.4

E000 LXI H,E100 E003 MVI M,3E E005 INX H E006 MVI M,05 E008 INX H E009 MVI M,47 E00B INX H E00C MVI M,48

ما هي نتيجة تتفيذ البرنامج السابق ؟

- 5. على ضوء نتيجة تتفيذ البرنامج السابق ما هي نتيجة تتفيذ الشفرات الموجودة
   في الأماكن E100 إلى E103 ?
  - 6. هل تتأثر الأعلام بأوامر الانتقال ؟
  - 7. اذكر الأعلام التي تتأثر بكل عملية من العمليات الحسابية والمنطقية ؟
- 8. إذا كانت محتويات المسجل A=F3H ومحتويات المسحل B=A4H فاكتب محتويات المسجل A بعد تتفيذ كل أمر من الأوامر التالية على نفس المحتويات السابقة ووضح أيضا كيف ستتأثر الأعلام بكل أمر :

ADD B

SUB B

SUB A

INC A

ANA B

ORA B

XRA B

ارسم خريطة تدفق للبرنامج التالى وما هى نتيجة تنفيذه :

E000 MVI L,50H

E003 MVI H, E1H

E005 MOV M.A

E006 DCR L

E007 JNZ E005

- 10. ماذا يحدث لو كتبنا البرنامج السابق عند E100 بدلا من E000 ؟
- 11. أعد كتابة البرنامج السابق مستخدما العلامات Labels ؟ وما هـــى ممـيزات البرنامج مكتوبا بهذه الصورة ؟
  - 12. كم عدد بوابات الإدخال التي يستطيع المعالج 8085 التعامل معها؟
  - 13. كم عدد بوابات الإخراج التي يستطيع المعالج 8085 التعامل معها؟
    - 14. على ماذا يتوقف هذا العدد ؟
- 15. هل هناك ما يمنع أن تكون بوابتى إدخال وإخراج لهما نفس الرقـم. كمثـال على ذلك 10 IN 05 و OUT 05 ؟
- 016. OUT C,reg هذا أحد أو امر الإخراج للبروسيسور Z80 والذي يعنى إخراج محتويات المسجل c على بوابة الإخراج التي رقمها في المسجل C فهل المعالج 8085 لديه ما يكافيء هذا الأمر ؟
  - 17. هل تتأثر الأعلام بأوامر الإدخال والإخراج ؟
- 18. أكتب برنامجا يقرأ محتويات البوابة 00 وإذا كانت هذه المحتويات زوجية يخزنها في الذاكرة ابتداء من العنوان E100 وإذا كانت فردية يخرجها على البوابة 00 ؟

- 19. المعالج 8085 لديه طريقتان فقط لعنونة الذاكرة وهما العنونة المباشرة والعنونة غير المباشرة ، اذكر الأوامر التي تستخدم مع كل من الطريقتين ؟
- 20. اذكر متى تفضل استخدام العنونة المباشرة ومتى تفضيل العنونة غير المباشرة؟
- 21. المعالجان Z80 و MC6800 بهما طرق أخرى لعنونة الذاكرة والتي منها على سبيل المثال العنونة المفهرسة indexed addressing فهل هناك طرق أخرى لعنونة الذاكرة لدى المعالج 8085 ؟
- 22. اكتب برنامجا يحسب عدد الوحايد الموجودة في محتويات المسجل A فمثلا إذا كان A=1110101 فبن عدد الوحايد A=1110101
- 23. اكتب برنامج يحسب أكبر قيمة عددية في لبايت في المدى العنوانيي E200H إلى E250H .
- 24. اكتب برنامج يحسب عدد البايتات التي تحتوى أصفرا والتي تحتوى أرقاما موجبة والني تحتوى أرقاما سالبة في المدى العنواني E100 إلى E150 .
- 25. اكتب برنامج يحسب عدد البايتات التي تحتوى بيانات فردية والتي تحتوى بيانات زوجية في المدى العنواني E100 إلى E150 .
- 26. المدى العنواني E100 إلى E150 يحتوى بيانات لإشارة صوت ، احسب كـــم مرة عبرت إشارة الصوت الصفر .
- 27. اكتب برنامج يقرأ بوابة الإدخال رقم 00 ويختبر البت الرابعة فيها ، فإذا كانت هذه البت كانت هذه البحتويات على البوابة 00 ، وإذا كانت هذه البت صفر يخرج محتوياتها على البوابة 01 .
- 28. اكتب برنامج يقرأ بوابة الإدخال رقم 00 إلى مالانهاية ويختبر البيانات التسى يقرأها ، فإن كانت فردية يخرجها على البوابة 00 ، وإن كانت زوجية يخرجها على على البوابة 01 . احسب أكبر معدل لدخول البيانات لكى يعمل هذا النظام فى الزمن المباشر real time .

# الفصل الخامس

يرمجة المعالج 2 80 Programming The Z80

Microprocessor

#### 1-5 مقدمة

يعتبر المعالج 280 صورة متطورة ومنقحة للمعالج Intel8085 حيث أن جميع أوامر الشريحة 8085 تتوافق مع الشريحة 280 ولكسن الشسريحة 8080 تمتاز ببعض المميزات الأخرى الغير موجودة في الشريحة 8085 والتي سسنراها في اثناء دراستنا لهذا الجزء . سنتبع في هذا الفصل نفس الطريقة التي اتبعناها في الفصل السابق حيث سنقسم أوامر الشسريحة 280 إلى مجموعات وسسندرس المنقصيل من كل مجموعة بعض الأوامر الكثيرة الاستخدام على أننا سنعرض في بالتفصيل من كل مجموعة بعض الأوامر حيث يمكن للقارىء الرجوع إليها . ولقد تعمدنا أن نتبع نفس طريقة الشرح في الفصل السابق حتى يتمكن من يريد أن يتتبع المعالج 280 فقط دون اللجوء إلى مراجعة أي معالج آخر قد لا يحتساح اليه في أثناء تدريبه ، كما أننا سنعرض مقارنات بسيطة بين البروسيسور 280 و البروسيسور 280 في بعض المواقف التي تتطلب ذلك حتى تكتمل الفائدة لمن يريد ذلك .

### 2-5 مجموعة أوامر الانتقال Transfer instructions

يقوم أي أمر من أوامر هذه المجموعة بنقل معلومة (بايت) من مكان لأخر حيث المكان الذي تخرج منه المعلومة سنسميه المصدر Source وسنرمز له أحيانا بالرمز SSS و هذا المكان قد يكون مسجلا داخل شريحة المعلومة فسوف نسميه الهدف من بايتات الذاكرة ، وأما المكان الذي ستذهب إليه المعلومة فسوف نسميه الهدف Destination وسنرمز له أحيانا بالرمز ddd وهذا المكان أيضا قد يكون مسجلا داخل شريحة المعالج وقد يكون بايتا من بايتات الذاكرة كما سنري . تمتاز جميع أوامر الانتقال الخاصة بالشريحة 280 بأن لها نفس الأحرف مهما كان مصدر أو هدف المعلومة وهذه الأحرف هي LDA التي هي اختصارا لكلمة LOAD أو حمل ، وذلك على العكس من الشريحة 885 التي تستخدم عددا أكثر من الأحرف والتي منها كال MOV و الإراف والتي تستخدم على الخاصة كما رأينا في الفصل السابق ، لذلك سنتناول أوامر كل منها في حالة الشريحة 280 على حسب مصدر وهدف المعلومة كما يلي :

1-2-5 نقل معلومة من مسجل إلى مسجل آخر الصورة العامة لهذا الأمر هي:

LD ddd,sss

مسجل sss حسجل

ومعناه تحميل المسجل ddd بمحتويات المسجل SSS ، لاحظ أن الذى يتم نقله من المسجل SSS ، لاحظ أن الذى يتم نقله من المحتويات فقط أما محتويات المسجل فتظل كما هي لا تتغير . من الأمثلة على ذلك ما يلى :

- الأمر LD A,B حيث سيقوم هذا الأمر بنقل (نسخ) محتويات المسجل B (المصدر) إلى المسجل A (الهدف) .
  - الأمر LD C,H سيقوم بتحميل المسجل C بمحتويات المسجل H.
- الأمر LD B,B سيقوم بتحميل المسجل B بمحتويات المسجل B . لاحسظ أن تأثير هذا الأمر يكافىء تماما "لا تعمل شيئا" وهذه العملية تكون مهمة جدا في الكثير من التطبيقات ولذلك فقد أفرد لها أمر خاص بها وهو الأمر NOP أى No operation أو لا تعمل شيئا ، وهذا الأمر سنراه في الكثير من التطبيقات القادمة إن شاء الله . الشفرات الستعشرية لجميع أو امر الانتقال بين جميسع المسجلات بعضها البعض يوضحها شكل (5-1) . بالنظر لهذا الشكل نجد أنه إذا أردنا مثلا نقل محتويات المسجل A إلى المسجل لا نستخدم الأمر LD L,A الذي شفرته من شكل (5-1) هي OP . جميع أو امر نقل المعلومة من مسجل إلى آخر تتكون من بايت واحدة فقط تسمى OP Code وهي اختصار العملية .

#### 2-2-5 تحميل مسجل بمعلومة فورية أو ثابت

فى الكثير من التطبيقات نحتاج لتحميل مسجل من المسجلات بثابت معين ، في الكثير من الصورة العامة لمثل هذه الأوامر كما يلى :

LD ddd,data8

ddd لمسجل data8 ←

ومعناه حمل المسجل ddd بالمعلومة الفورية أو الثابت data8 ، لاحظ أن ganul ومعناه حمل المسجل ddd بالمعلومة الفورية أو الثابت هذه المجموعة تتكون مسن التين بايت واحدة هي شفرة الأمر Op Code والثانيسة هي البايت data8 أو الثابت. شكل (2-5) يبين الشفرات الستعشرية لعملية تحميل أي مسجل من المسجلات بثابت data8 ، من هذا الشكل نلاحظ أنه التحميل المسجل D بالقيمة المسجلات بثابت LD D,55H والذي ستكون شفرته الستعشرية كما يلي :

16

55H

حيث 16 (البايت الأولى) هي op code كما في شكل (2-5) أما البايت الثانية فهي قيمة الثابت المراد تحميله في المسجل D وهو 55H ، لاحظ أن H بعد الرقم تعنى أن هذا الرقم ممثل في النظام الستعشرى .

| مسجل الهدف<br>Destination register |    |    | _  | ل المص<br>ce reg | -  |    |    |
|------------------------------------|----|----|----|------------------|----|----|----|
|                                    | A  | В  | C  | D                | E  | H  | L  |
| Α,                                 | 7F | 78 | 79 | 7A               | 7B | 7C | 7D |
| В,                                 | 47 | 40 | 41 | 42               | 43 | 44 | 45 |
| С,                                 | 4F | 48 | 49 | 4A               | 4B | 4C | 4D |
| D,                                 | 57 | 50 | 51 | 52               | 53 | 54 | 55 |
| Ε,                                 | 5F | 58 | 59 | 5A               | 5B | 5C | 5D |
| Н,                                 | 67 | 60 | 61 | 62               | 63 | 64 | 65 |
| L,                                 | 6F | 68 | 69 | 6A               | 6B | 6C | 6D |

شكل (5-1) الشفرة الستعشرية لجميع أوامر الإنتقال بين المسجلات

| A     | В     | C     | D     | E     | н     | , <b>L</b> |
|-------|-------|-------|-------|-------|-------|------------|
| 3E    | 06    | 0E    | 16    | 1E    | 26    | 2E         |
| data8      |

شكل (2-5) الشفرات الستعشرية لأوامر تحميل المسجلات بمعلومة فورية أو data8

#### مثال 5. 1

المطلوب تحميل المسجلات H, E, D, C, B, A بالمعلومات الفورية أو الثوابيت الأتية: 06,05,04,03,02,01 وبعد ذلك يتم إجراء إزاحة دورانية لهذه المحتويات بحيث تذهب محتويات المسجل A إلى المسجل B وتذهب محتويات المسجل B المسجل B المسجل H المسجل B المسجل A ألى المسجل المسابق يبين نفس هذا البرنامج مكتوبا بلغة الأسمبلي الخاصة بالشريحة 8085 وبمقارنة الشفرات المستعشرية لمكل المرنامجين في الشكلين (5–3 و 4–3) نجد أن هناك تطابقا تاما في الشفرات المستعشرية في المسكلين وهذا يبين مدى التطابق بين الشريحتين 280 و 8085 فيان أي برنامج مكتوبا بالشفرات المستعشرية المسريحة 8085 و 8085 و 8085 المسجل على المستخدام المسجل على المتحدام المسجل المتعشرية المسجل المتحدام المسجل المتحدان المتحدام المسجل المتحدد المت

وأما البرامج المكتوبة بالشفرات الستعشرية للشريحة Z80 فليس بالضرورة أنـــه يمكن تنفيذه على الشريحة 8085 وذلك لأن الشريحة Z80 تحتوى على عدد أكــشر من الأوامر الغير معرفة لدى الشريحة 8085 .

| العناوين | شقرات أسمبلي | شفرات            |
|----------|--------------|------------------|
|          |              | شفرات<br>ستعشرية |
| E000     | LD A,01      | 3E               |
|          |              | 01               |
| E002     | LD B,02.     | 06               |
|          |              | 02               |
| E004     | LD C,03      | 0E               |
|          |              | 03               |
| E006     | LD D,04      | 16               |
|          |              | 04               |
| E008     | LD E,05      | 1E               |
|          |              | 05               |
| E00A     | LD H,06      | 26               |
|          |              | 06               |
| E00C     | LD L,A       | 6F               |
| E00D     | LD A,H       | 7C               |
| E00E     | LD H,E       | 63               |
| E00F     | LD E,D       | 5A               |
| E010     | LD D,C       | 51               |
| E011     | LD C,B       | 48               |
| E012     | LD B,L       | 45               |

شكل (3-5) برنامج الأزاحة الدورانية

لتنفيذ البرنامج الموجود في شكل (5-3) فإنه يمكن أن ندخل في الذاكرة RAM ونكتب الشفرات الستعشرية ابتداء من العنوان E000 وبعد الانتهاء من كتابة البرنامج في الذاكرة ننفذه باستخدام الأمر B000 و أما إذا كان الميكروكومبيوتر الذي نستخدمه به الأسمبلر الخاص بالمعالج Z80 فإنه يمكننا في هذه الحالة كتابة البرنامج بلغة الأسمبلي مباشرة ثم تتفيذه وسنترك تفاصيل عملية إدخال البرنامج لأنها تختلف من شخص لآخر ولكننا ننصح أن تكتب البرامج الأولى في مرحلة التدريب بالشفرات الستعشرية ثم يعد ذلك تكتب بلغة الأسمبلي وننصح أيضا أن يتم تنفيذ البرامج الأولى بطريقة الخطوة خطوة حتيى يتمكن

المتدرب من ملاحظة تأثير كل أمر على حده ومتابعة تحميل المسجلات وانتقال البيانات من مسجل لآخر .

يمكن أيضا تحميل زوج من المسجلات بمعلومة مكونة من 16 بتا كما يلى : LD rp,data16

data16 زوج المسجلات

حيث rp ترمز لأى زوج من أزواج المسجلات المتاحة في المعالج Z80 وهيي rp ترمز لأى زوج من أزواج المسجلات المتاحية DY, IX, SP, HL, DE, BC (راجع شكل (2-6) لترى أزواج المسجلات المتاحية في الشريحة Z80 . شكل (3-6) يبين الشفرات الستعشرية المصاحبة لكل زوج في هذا الأمر . لاحظ أن جميع هذه الأوامر ستتكون من ثلاث بايتات ، واحيدة (الأولى ) ستكون شفرة الأمر op code والاثنتان التاليتان سيتحتويان المعلومية الأمر سيتكون من أربعة بايتات ، إثنتان لشفرة الأمر op code واثنتان للمعلومية الأمر سيتكون من أربعة بايتات ، إثنتان لشفرة الأمر op code واثنتان للمعلومية كلمة أزواج ولكن ليكن راسخا في العلم أن كل واحدة منها عبارة عين مسجل كلمة أزواج ولكن ليكن راسخا في العلم أن كل واحدة منها عبارة عين مسجل واحد مكون من 16 بت و لا يمكن تقسيمه إلى مسجلين كما هو الحال في السزوج واحد الذي يمكن استخدامه كمسجلين B و C . كمثال على ذلك فإن الأمر :

سيحمل الزوج HL بالمعلومة E100H حيث ستذهب البايت الأولى من المعلومة E100H . E100H المسجل E100H والبايت الثانية من المعلومة E100H ستذهب إلى المسجل E100H . الشفر ات الستعشرية لهذا الأمر ستكون كالتالى :

21 00 E1

#### 3-2-5 نقل معلومة من مسجل إلى الذاكرة والعكس

لنقل معلومة من مسجل في داخل المعالج Z80 إلى أي مكان في الذاكرة أو العكس يمكن استخدام طريقة من ثلاث طرق متاحة لهذا الغرض وهي كالتالي:

|   | BC     | DE     | HL     | SP     | IX     | . <b>TY</b> |
|---|--------|--------|--------|--------|--------|-------------|
| ļ | 01     | 11     | 21     | 31     | DD21   | FD21        |
|   | data16 | data16 | data16 | data16 | data16 | data16      |

شكل (5-4) الشفرات الستعشرية لأوامر تحميل أزواج المسجلات بمعلومة فورية أو ثابت data16

1-3-?-5 الطريقة المباشرة Direct addressing

نى هذه الطريقة يكون عنوان البايت المراد التعامل معها موجودا فى الأمر نفسه (فى البايت الثانية والثالثة) ولذلك فإن مثل هذه الأوامر تتكون دائما مسن شلات بايتات واحدة هى شفرة الأمر op code واثنتان للعنوان المراد التعسامل معه ماك أمران فقط تحت هذه المجموعة ، أمر خاص بنقل المعلومات من مسجل التراكم إلى الذاكرة والآخر خاص بنقل المعلومات من الذاكرة إلى مسجل التراكم A ولذلك فاننا نلاحظ أن التعامل بالطريقة المباشرة لا يكون إلا بين مسجل التراكم التراكم فقط والذاكرة ، فإذا أردنا نقل معلومة مثلا من المسجل B إلى الذاكرة . الأمر بهذه الطريقة فإننا ننقل المعلومة أو لا إلى المسجل A ثم منه إلى الذاكرة . الأمر الأول فى هذه المجموعة هو الأمر :

LD A,(addr) . A المسجل (addr)

الشفرة الستعشرية لهذا الأمر هي:

3A

البايت ذات القيمة الصغرى من العنوان addr البايت ذات القيمة العظمى من العنوان

حيث سيقوم هذا الأمر بنقل محتويات بايت الذاكرة التي عنوانها في الاثنين بليت الثانية والثالثة في الأمر نفسه إلى مسجل التراكم A. ونؤكد هنا علي كلمة محتويات حتى لا يظن البعض أن العنوان نفسه هو الذي يوضع في المسجل A كما يوحى شكل الأمر لأول وهلة ولقد تم وضع قوسين حول كلمة علمه فلي الصورة الحرفية للأمر للتأكيد على ذلك ولأنه بدون هذين القوسين لن يستطيع الأسمبلر التمييز بين ما إذا كان الرقم addr عنوانا أم معلومة فورية مطلوب تحميلها في المسجل A. كمثال على ذلك انظر إلى الأمر:

LD A,(E100)

حيث يقوم هذا الأمر بتحميل المسجل A بمحتويات العنوان E100 من الذاكوة . الأمر الثاني من أوامر هذه المجموعة هو الأمر :

LD (addr),A (addr)← A المسجل

والشفرة الستعشرية لهذا الأمر هي:

32

البايت ذات القيمة الصغرى من العنوان addr البايت ذات القيمة العظمى من العنوان

حيث سيقوم هذا الأمر بنقل محتويات المسجل A إلى بايت الذاكرة التى عنوانها موجود فى البايت الثانية والثالثة من الأمر نفسه ، أى أن هذا الأمر يقوم بالعملية العكسية للأمر السابق . كمثال على ذلك انظر إلى الأمر :

LD (E100),A

والذي شفرته الستعشرية ستكون:

32

00

El

حيث سيقوم هذا الأمر بتخزين محتويات المسجل A في بسايت الذاكرة التي عنوانها E100 . بذلك نكون قد انتهينا من الطريقة المباشرة لعنونة أو التعامل مع الذاكرة . إن هذه الطريقة كما رأينا مثلها مثل أن تقول لصديقك أحمد ياأخي ياأحمد وأنت مسافر إلى الرياض أرجوك أن تعطى هذا الخطاب لأخصى محمد هناك وعنوانه موجود على الخطاب مباشرة ، هنا صديقك أحمد الذي يمثل المعالج الذي سينفذ الأمر سيعرف عنوان أخيك في الرياض من على الخطاب مباشرة حيث الخطاب في هذه الحالة يعتبر الأمر المطلوب تنفيذه .

#### 2-3-2-5 الطريقة غير المباشرة Indirect addressing

في هذه الطريقة لا يكون عنوان البايت المراد التعامل معها في الذاكرة موجودا مباشرة في الأمر نفسه ولكنه يكون موجودا في مكان آخر وعلى المعالج الذهب الجي هذا المكان أو لا وقبل تتفيذ الأمر لمعرفة العنوان . هذا المكان يكون زوجا من المسجلات و لابد أن يكون زوجا لأن العنوان كما نعرف دائما يتكون من 16 بت ، وعادة يكون هذا الزوج هو الزوج الله الصورة العامة للأمر في هذه الحالة بلغة الأسمبلي تكون كما يلي :

LD ddd,(HL) (HL)

حيث سيقوم هذا الأمر بنقل محتويات بايت الذاكرة التري عنوانها في زوج المسجلات HL إلى المسجل ddd . الصورة العكسية لهذا الأمر هي :

LD (HL),sss

(HL) sss المسجل

حيث سيقوم هذا الأمر بنقل محتويات مسجل المصدر إلى بايت الذاكرة التى يوجد عنوانها في رُوج المسجلات HI. شكل (5-5) يبين الشفرات الستعشرية ليهذه الأوامر في حالة استعماله مع جميع المسجلات الموجودة في الشريحة Z80 وكما ذكرنا فإن العنوان لابد وأن يكون موجودا في الزوج HI. هذه الأوامر (أو امسر الطريقة غير المباشرة) ستكون جميعها مكونة من بايت واحدة فقط وهي شهرته الأمر op code . كمثال على ذلك الأمر HI والذي سيتكون شهرته الستعشرية AI حيث سيقوم هذا الأمر بنقل محتويات البايت التي عنوانها في الزوج AI المسجل AI الامر وجود القوسين حول الزوج AI في جميع

هذه الأوامر للدلالة على أن المقصود هو محتويات العنوان الموجــود فــى HL وليس القيمة الموجودة في HL مباشرة .

|      |      | A  | В  | C  | D  | E  | H  | L  |
|------|------|----|----|----|----|----|----|----|
| ddd  | (HL) | 7E | 46 | 4E | 56 | 5E | 66 | 6E |
| (HL) | SSS  | 77 | 70 | 71 | 72 | 73 | 74 | 75 |

شكل (5-5) الشفرات الستعشرية لأو امر الانتقال بين المسجلات والذاكرة بالطريقة غير المباشرة

هناك ميزة يمتاز بها المسجل A عن باقى مسجلات الشريحة فى حالة التعامل بينه وبين الذاكرة بالطريقة غير المباشرة وهى أن عنوان البايت المراد التعامل معها فى هذه الحالة يمكن وضعه فى أى زوج من أزواج المسجلات الأخرى وليس بالضرورة الزوج HL كما سبق ، وذلك كما قلنا كحالة خاصة فقط للمسجل A . شكل (5–6) يبين الشفرة الستعشرية والأسمبلى وما يقوم به كل واحد من هذه الأوامر .

| الشفرة الأسمبلي | الشفرة<br>الستعشرية | ما يفعله الأمر          |
|-----------------|---------------------|-------------------------|
| LD A,(BC)       | 0A                  | A ← (BC)                |
| LD A,(DE)       | 1A                  | <b>A</b> ← (DE)         |
| LD (BC),A       | 02                  | (BC) <del>&lt;−</del> A |
| LD (DE),A       | 12                  | (DE)← A                 |

شكل (5-6) أو امر الانتقال بين المسجل A والذاكرة بالطريقة غير المباشرة

كما رأينا فإن الطريقة غير المباشرة في التعامل مع الذاكرة مثلها مثل أن تقول لصديقك أحمد ياأخي ياأحمد وأنت مسافر إلى الرياض خذ هذا الخطاب وأعطه لأخي محمد ولكن أرجوك قبل سفرك أن تمر على والدي لتعرف منه عنوان أخي محمد في الرياض لأني لا أجرفه . هنا صديقك أحمد يمثل المعالج الذي سيقوم بالتنفيذ والوالد يمثل المسجلين HL حيث يحتويان العنوان المراد التعامل معه واللذان لابد من المرور عليهما قبل تتفيذ الأمر . السؤال الآن كيف نضعوان منوان ما في زوج من المسجلات ؟ إن هذه العملية بسيطة جدا حيث يستخدم فيها أوامر تحميل زوج مسجلات بمعلومة فورية أو ثابت مكون من 16 بت والتي درسناها في الجزء السابق (5-2-2 تحميل مسجل بمعلومة فورية) .

#### 3-2-5 طريقة الفهرسة لعنونة الذاكرة Indexed addressing

هناك مسجلان لم نتكلم عنهما تفصيليا إلى الآن وهما المسجلان IX و IY وكل منهما يتكون من 16 بت . هذان المسجلان يختلفان عن أزواج المسجلات الأخرى في أنه لا يمكن استخدام أي منهما كمسجلين 8 بتات منفصلين ولكن كل منهما يستخدم كمسجل 16 بت مثل مسجل عداد البرنامج program منهما يستخدم كمسجل 16 بت مثله في ذلك مثل مسجل عداد البرنامج counter أو مؤشر المكدسة stack pointer . هذان المسجلان يستخدمان في عملية الإشارة إلى بايتات الذاكرة تماما مثل الزوج HL ولكن بإمكانيات أكتر ، ولكي نفهم ذلك انظر إلى الأمر التالى :

LD B,(IX+5)

هذا الأمر سيقوم بتحميل المسجل B بمحتويات بايت الذاكرة التى عنوانها عبارة عن حاصل جمع محتويات المسجل IX زائد خمسة . لكى نوضح هاذا الأمر افترض الوضع التالى:

| В  | IX   | E105 |
|----|------|------|
| 05 | E100 | 66   |

بعد تنفيذ الأمر (LD B,(IX+5) سيصبح الوضع كالتالى:

| В  | IX   | E105 |
|----|------|------|
| 66 | E100 | 66   |

الرقم الذي يضاف على محتويات المسجل IX أو المسجل IY يسمى "الإزاحــة" displacement وهذه الإزاحة تشغل بايت كاملة ولذلك فإن قيمتها ستتراوح بيـن 127+ و 128- حيث الإزاحة الموجبة معناها إضافــة إلــي محتويـات مسجل الفهرسة (IX, IY) وأما الإزاحة السالبة فمعناها طرح من مســـجل الفهرســة. الشفرات الستعشرية لجميع هذه الأوامر موجودة في جداول الأوامر الموضحــة في نهاية هذا الفصل.

#### **3−5** تــمــاريــن

استخدم قائمة أو امر الانتقال الخاصة بالشريحة 280 لحل التمارين الموجودة فى الجزء 4-3 فى الفصل السابق .

### 4-5 مجموعة أو امر الحساب Arithmatic Instructions

سندرس في هذا الجزء بعض الأوامر التي تقوم بإجراء العمليات الحسابية الأولية وهي الجمع والطرح ، وكما علمنا من قبل فإن مسجل التراكم لابد وأن يكون طرفا في أي عملية من هذه العمليات كما أن نتيجة هذه العملية سواء كانت جمعا أو طرحا تكون دائما موجودة في مسجل التراكم A . هناك أيضا خاصية مهمة في مجموعة أوامر الحساب (ومثلها أيضا أوامر المنطق كما سنري) وهي أنسة نتيجة تنفيذ أي أمر من هذه الأوامر فإن الأعلام الموجودة في مسجل الحالة نتيجة تتفيذ أي أمر من هذه النتيجة . راجع مسجل الحالة ومحتوياته ومتى يكون أي علم من أعلامه يساوي صفرا أو واحدا وذلك في الفصل الثاني . كما ذكرنا فإن طرفا من طرفي العملية الحسابية أو معامل من معامليها لابد وأن يكون موضوعا في المسجل A وأما الطرف الثاني أو المعامل الثاني فإن مصدره موضوعا في المسجل A وأما الطرف الثاني أو المعامل الثاني فإن مصدره

| مصدر المعامل الثاني للعملية        | الرمز المستخدم |
|------------------------------------|----------------|
| الحسابية                           | ·              |
| مسجل 8 بـــت مــن مســجلات         | reg            |
| المعالج .                          |                |
| بايت من بايتات الذاكرة عنوانــها   | (HL)           |
| في HL ٠                            |                |
| ثابت أو معلومة فورية مكونة مـن     | data8          |
| 8 بت ،                             |                |
| بايت من بايتات الذاكرة معنونـــــة | (IX+d)         |
| بطريقة الفهرسة باستخدام            | (IY+d)         |
| المسجلين IX أو IY                  |                |

# 5-4-1 الأمران ADD و SUB الصورة العامة لأمر الجمع ADD هي :

ADD A,reg

 $A \leftarrow A + reg$ 

حيث سيقوم هذا الأمر بجمع محتويات المسجل reg مع محتويات المسجل A ووضع النتيجة في المسجل A مع التأثير على الأعلام لاحظ أننا في حالة

أسمبلر الشريحة 8085 كنا نكتب هذا الأمر ADD reg بدون ذكر المسجل A على أساس أنه بديهى أن المعامل الثانى للعملية يكون فى المسجل A ، أما فى أسمبلر الشريحة 280 فلابد من ذكر طرفى العملية الحسابية بالرغم من أن أحدهما يكون دائما المسجل A وإن كانت بعض المراجع تهمل ذلك . الصور العامة الأخسرى لأمر الجمع ستكون كالتالى :

ADD A,(HL)

حيث سيقوم هذا الأمر بجمع محتويات بايت الذاكرة التي يوجد عُنوانها في حيث سيقوم هذا الأمر بجمع محتويات المسجل A وتوضع النتيجة في المسجل A ADD A, data8

. A وتوضع النبيجة في المسجل A مع المسجل A مع المسجل ADD A,(IX+d) ADD A,(IY+d)

حيث سيجمع محتويات المسجل A مع محتويات بايت الذاكرة التى عنوانها عبارة عن محتويات المسجل IX أو IY زائد الإزاحة d وتوضع النتيجية في المسجل A. بنفس الطريقة يمكن كتابة الصورة العامة الأمر الطرح تبعا لمصدر المعامل الثاني كما يلى:

SUB A,reg

 $A \leftarrow A - reg$ 

SUB A,(HL)

A← A - (HIL)

SUB A, data8

A← A - data8

SUB A,(IX+d)

SUB A,(IY+d)

 $A \leftarrow A - (IX+d)$ 

 $A \leftarrow A - (IY + d)$ 

في جميع هذه الأوامر يتم طرح المعامل الثاني (IY+d), reg) من المسجل A وتوضع النتيجة في المسجل A ، أي أننا نؤكد (IX+d), (IX+d)) من المسجل A وتوضع النتيجة في المسجل A ، أي أننا نؤكد هنا على أن المطروح منه يكون دائما المسجل A . لاحظ أن المسجل A يذكر مع هذا الأمر أيضا وذلك بالطبع لا دخل للمستخدم فيه ولكنه من الشروط التي يفرضها الأسمبلر (كما في بعض المراجع) ، سنهمل ذكر الشفرات الستعشرية للأوامر ابتداء من هذا الموضع ومن يريد التعرف عليها أو استخدامها فعليه الاستعانة بالأشكال الخاصة بالأوامر في نهاية هذا الفصل .

#### مِثال 5-2

افترض المحتويات الآتية للمسجلين A و B قبل تنفيذ الأمرين ADD و SUB:



ولكى نرى كيفية تأثر الأعلام بنتيجة هذه العملية سنجرى عملية الجمع على الشفرات الثنائية لكل من الرقمين كما يلى:



الآن افترض أننا نفذنا أمر الطرح SUB B على المحتويات الأولى للمسجلين أى A=AAH و B=A5H فإنه بعد تنفيذ هذا الأمر ستصبح محتويات المسجلين كالتالى:



ولكي نرى كيف تمت عملية الطرح وكيف تأثرت الأعلام سنجرى عملية الطرح على الشفرات الثنائية لمحتويات المسجلين A و B كالتالى:

كما نعلم فإن عملية الطرح الثنائي يتم تحويلها إلى عملية جمع حيث سنجمع محتويات المسجل B للمطروح منه) مع المتمم الثنائي لمحتويات المسجل B (المطروح) (انظر الملحق الأول في نهاية الكتاب لمراجعة عمليات الجمع والطرح الثنائي) . المتمم الثنائي لمحتويات المسجل B (10100101) هو 10101011 وبذلك تصبح عملية الطرح عملية جمع كالتالي :

#### A = 10101010

# + 01011011 = المتمم الثنائي لمحتويات المسجل B

00000101

وبناء على ذلك ستكون الأعلام كالتالى:

- طالما أن البت الأولى لا تساوى صفرا فالنتيجة لا تساوى صفرا ويكون علم الصفر ZF=0.
- تحتوى النتيجة على عدد زوجى من الوحايد (اثنين) لذلك سيكون علم الباريتي و احدا ، PF=1 .
- هذاك حمل من البت الثالثة إلى البت الرابعة في حالة الجمع لذلك فعلم الحمسل النصفي HCF=0.
- آخر بت (رقم 7) تساوى صفرا ، لذلك فالنتيجة موجبة وعلم الإشارة يكــون دائما مساويا لمحتويات آخر بت , إذن SF=0 .
- المفروض في عمليات الطرح يهمنا أن نعرف إذا كان هناك استلف أم لا لأنه في عملية الطرح لن يكون هناك حمل بما أن عملية الطرح قد حولت إلسي عملية جمع لذلك فإنه إذا كان هناك حمل في عملية الجمع فان ذلك يعني أنه لـن يكون هناك استلاف في عملية الطرح وسيكون علم الحمل CYF=0 وهي الحالسة التي معنا الآن والعكس صحيح إذا لم يكن هناك حمل في عملية الجمع . وهـــذا هو ما طبقناه في حالة العلم HCF

#### 2-4-5 الأمران ADC و SBC

بالنسبة للأمر ADC فإنه يجمع المعامل الثاني سواء كان في مسجل أو ذاكرة أو قيمة فورية مع محتويات المسجل A مع محتويات علم الحمـــل CY (صفــر أو واحد) ويضع النتيجة في المسجل A . الصورة العامة لهذه الأوامر وعلى حسب مصدر المعامل الثاني ستكون كما يلي:

ADC A, reg

 $A \leftarrow A + CY + reg$ 

ADC A,(HL)

 $A \leftarrow A + CY + (HL)$ 

ADC A, data8

 $A \leftarrow A + CY + data8$ 

ADC A<sub>3</sub>(IX+d)

 $A \leftarrow A + CY + (IX+d)$ 

ADC A,(IY+d)

 $A \leftarrow A + CY + (IY+d)$ 

يمكننا الآن تكرار نفس القول بالنسبة لأمر الطرح SBC حيث يقوم هذا الأمر بطرح المعامل الثاني سواء كان في مسجل أو ذاكرة أو قيمة فورية مع محتويات علم الحمل CY (صفر أو واحد) من المسجل A ثم توضع نتيجة الطرح في المسجل A ، نؤكد هنا على أن المطروح منه دائما هو المسجل A . الصورة العامة لهذه الأوامر وعلى حسب مصدر المعامل الثاني ستكون كما يلى :

SBC A,reg
A ← A - CY - reg
SBC A,(HL)
A ← A - CY - (HL)
SBC A,data8
A ← A - CY - data8
SBC A,(IX+d)
A ← A - CY - (IX+d)
SBC A,(IY+d)
A ← A - CY - (IY+d)

#### مثال 5-3

| E000 E001               | LD C,F9H    |
|-------------------------|-------------|
| E002 E003               | LD B,23H    |
| E004 E005               | LD E,35H    |
| E006 E007               | LD D,9AH    |
| E008                    | LD A,C      |
| E009                    | ADD A,E     |
| E00A E00B E00C          | LD (E100),A |
| E00D                    | LD A,B      |
| E00E                    | ADC A,D     |
| E00F E010 E011          | LD (E101),A |
| E012 E013               | LD A,00     |
| E014                    | ADC A,A     |
| E015 E016 E <b>0</b> 17 | LD (E102),A |
|                         | / -> 4      |

شكل (5-7) برنامج المثال 5-3

المطلوب جمع الرقمين 23F9H و 9A35H ووضع نتيجة الجمسع في أمساكن الذاكرة E100 و E101 و E102 .

هذا المثال هو المثال رقم 4-11 وقد سبق حله كتطبيق على أمر الجمع مع الحمل فى حالة الشريحة 8085 ويبين شكل (6-6) رسما توضيحيا ومخطط السير والبرنامج لطريقة حل هذا المثال ، لذلك يمكن مراجعته أو لا وسنعيد كتابة البرنامج فقط بلغة الأسمبلى الخاصة بالشريحة 280 فى شكل (6-7) . قبل أن نترك أو امر الجمع و الطرح يجب أن نفهم جيدا متى يكون من الضرورى

استخدام الأمر ADC ؟ ومتى يكون من الضرورى عدم استخدامه؟ مئسلا في المثال السابق كان من الضرورى عدم استخدام الأمر ADC في عمليسة الجمع الأولى (E+C) ولكن في هذه الحاله لابد من استخدام الأمر ADD خوفا من أن يكون علم الحمل CY به واحد من أي عملية سابقة ونحن لا ندرى فيجمع مع عملية الجمع الأولى إذا استخدمنا الأمر ADC وتكون النتيجة خاطئة . أما في عملية الجمع الثانية (D+B+CY) فإنه لابد من استخدام الأمر ADC لأننا نريد هنا أن ناخذ قيمة علم الحمل في الاعتبار .

#### 3-4-5 الأمران INC و DEC

هذان الأمران يستخدمان لزيادة أو إنقاص واحد على أو من محتويات مسجل أو بايت من بايتات الذاكرة . الصورة العامة للأمسر INC وعلى حسب مكان المعلومة يمكن كتابتها كالتالى :

```
INC reg
reg \leftarrow reg + 1
INC (HL)
(HL) \leftarrow (HL) + 1
INC (IX+d)
(IX+d) \leftarrow (IX+d) + 1
INC (IY+d)
(IY+D) \leftarrow (IY+d) + 1
                بنفس الطريقة يمكن كتابة الصورة العامة للأمر DEC كما يلى:
DEC reg
reg \leftarrow reg - 1
DEC (HL)
(HL) \leftarrow (HL) - 1
DEC (IX+d)
(IX+D)\leftarrow (IX+d) - 1
DEC (IY+d)
(IY+d) \leftarrow (IY+d) - 1
```

#### 5-4-4 العمليات الحسابية على أزواج المسجلات

عند إجراء العمليات الحسابية على أزواج المسجلات يلعب السزوج HL دور مسجل التراكم من حيث أن المعامل الأول في العملية الحسابية لابد وأن يكبون في الزوج HL ونتيجة العملية الحسابية تذهب دائما إلى الزوج HL . يجب أن نعلم أنه عند إجراء العمليات الحسابية على أزواج المسجلات أن الأعلام لا تتأثر

بهذه العمليات في الكثير من الأحيان ويجب النظر في حالة كل أمر منفصلة . الصورة العامة للأمرين INC و DEC في هذه الحالة هي :

INC rp

 $rp \leftarrow rp + 1$ 

DEC rp

rp←--rp -1

حيث rp ترمز لأى زوج من أزواج المسجلات SP, HL, DE, BC أو مسجل من المسجلات ال 16 بت وهي المسجل IX أو المسجل IY . كأمثلة على ذلك انظر الي الأوامر التالية :

INC HL

DEC SP

**INCIX** 

الأمر الأول سيزيد واحدا على محتويات المسجلين HL والثانى سينقص واحـــدا من محتويات المسجل SP والثالث سيزيد واحدا على محتويات المسجل IX . الأوامر DEC rp و DEC rp ليس لها تأثير على الأعلام .

من أوامر الجمع والطرح التي تجرى على أزواج المسجلات ما يلي :

ADD HL,rp

HL←—HL + rp

ADC HL,rp

 $HL \leftarrow HL + rp + CY$ 

SBC HL,rp

HL← HL - rp - CY

في جميع هذه الأوامر ترمز rp لأي زوج من الأزواج SP, HL, DE, BC ما عدا المسجلين IX, IY فلا يمكن استخدامهما مع هذه الأوامر . لاحظ أيضا أن أمر الطرح الوحيد المتاح هو أمر الطرح مع الحمل SBC ولذلك فإنه عند إجراء أي عملية طرح بدون أخذ علم الحمل في الحسبان يجب في هذه الحالة التأكد من أن علم الحمل يساوي صفرا . الأمر ADD HL,rp ليس له تأثير على الأعلام وأما الأمران ADC HL,rp فيؤثران على الأعلام ما عدا علم الحمل الأمران ADC المنابقة هو المسجلين النصفي HC . نؤكد هنا على أن المطروح منه في الأوامر السابقه هو المسجلين ADC التراكم في عمليات الجمع على أزواج المسجلات ، وهذه الأوامر هي :

| $IX \leftarrow IX + BC$  | ADD IX,BC |
|--------------------------|-----------|
| $IX \leftarrow IX + DE$  | ADD IX,DE |
| $IX \leftarrow IX + SP$  | ADD IX,SP |
| $IX \leftarrow -IX + IX$ | ADD IX,IX |
| $IY \leftarrow IY + BC$  | ADD IY,BC |
| $IY \leftarrow IY + DE$  | ADD IY,DE |

 $IY \leftarrow IY + SP$  ADD IY,SP  $IY \leftarrow IY + IY$  ADD IY,IY

جميع هذه الأوامر تؤثر على الأعلام ما عدا علم الحمل النصف \_\_ HC وأيضا جميع هذه الأوامر ليس لها نظير لعملية الطرح.

#### 5-4-5 أمر المقارنة Compare Instruction

هناك أمر واحد فقط للمقارنة حيث أن عملية المقارنة لا تجرى على أى معلومة مكونة من 16 بت . لكي تتم عملية المقارنة فإن أحد المعاملين لابد وأن يكون في المسجل A والمعامل الآخر يكون إما في مسجل من مسجلات المعالج أو في بايت من بايتات الذاكرة . عند تتفيذ أمر المقارنة يقوم المعالج بطرح محتويات المعامل الثاني من محتويات المسجل A وتهمل نتيجة الطرح تماما و لا تتغيير محتويات المسجل A نتيجة هذه العملية ولكن الذي يتأثر فقط بهذه العملية هدو الأعلام . الصورة العامة لأمر المقارنة وعلى حسب مصدر المعامل الثاني يمكن كتابتها كما يلي :

A - reg CP reg
A - (HL) CP (HL)
A - data8 CP data8
A - (IX+d) CP (IX+d)
A - (IY+d) CP (IY+d)

لاحظ أننا لم نكتب السهم الذي يوضح أين تذهب نتيجة عملية الطرح على الساس أن النتيجة تهمل كما ذكرنا . كأمثلة على ذلك انظر إلى الأوامر التالية :

CP B

CP 3FH

CP (IY+9)

A حيث سيقارن الأمر الأول محتويات المسجل B مع محتويات المسجل A 3FH وسيقارن الأمر الثانى محتويات المسجل A مع الثابت أو القيمة الفورية B وأما الأمر الثالث فسيقارن محتويات المسجل A مع محتويات بايت الذاكرة التى عنوانها تسعة زائد محتويات المسجل B .

#### <u>مثال 5−4</u>

اكتب برنامجا يجمع محتويات الخمس بايتات E104, E103, E102, E101, E100 ويضع النتيجة في البايت E10A على اعتبار أن النتيجة المتوقعة لن تزيد عن بايت واحدة ، أي لن يكون هناك حمل على الإطلاق . هذا المثال من الممكن أن يكون تدريبا جيدا على طرق الاتصال بالذاكرة التي تمت دراستها حتى الآن . شكل (5-8) يبين مخطط السير والبرنامج لهذا المثال مستخدمين طريقة الفهرسة

مع المسجل IX للاتصال بالذاكرة ، حاول كتابة البرنامج مرة أخرى مستخدما الطريقة غير المباشرة مع الزوج HL .



#### 5-5 تـمـاريـن

حل التمارين الموجودة في الجزء 4-5 في الفصل الرابع مستخدما أو امسر لغسة الأسمبلي الخاصة بالشريحة Z80.

## 6-5 مجموعة أوامر القفز Jump Instructions

القاعدة العامة أن المعالج يقوم بتنفيذ البرنامج حسب ترتيب الأوامر الموجودة فيه من أول البرنامج إلى نهايته . ولقد كنا حريصين في جميع الأمثلة السابقة علي المفاظ على هذه القاعدة ، ولكن هناك بعض المواقف أو قل بعض التطبيقات التي تتطلب الخروج على هذه القاعدة كأن يطلب منك مثلا تتفيذ عملية معينة التي تتطلب الخروج على هذه القاعدة كأن يطلب منك مثلا تتفيذ عملية معينة المعالج مثلا مراقبا لدرجة الحرارة في عملية صناعية معينة فإن عليه أن يقر المعالج مثلا مراقبا لدرجة الحرارة مخزنة في الذاكرة كمرجع وإذا زادت الحرارة عن حد معين يقوم المعالج بضرب جرس إنذار ، وإذا نقصت عن حد معين يشغل سخان لزيادتها ، مثل هذا البرنامج سيكون عبارة عن مجموعة من الأوامر التي تنفذ إلى مالانهاية طالما أن المعالج يراقب درجة الحرارة . لقد أتاح المعالج هذه العملية بتوفير بعض الأوامر التي تمكنك كمبرمج من القفز بعملية التنفيذ من مكان لآخر خلال البرنامج ، وهناك ثلاثة أنواع من القفر توفرها الشريحة 280 وهي كما يلي :

#### 1-6-5 القفز غير المشروط Unconditional jump

عند تنفيذ أى عملية قفز غير مشروط ينتقل المعالج بعملية التنفيذ إلى المكان الجديد دون أى قيد أو شرط، وهناك أمر واحد فقط من أوامر الشريحة 280 يقوم بهذه العملية والصورة العامة لهذا الأمر هى:

JP addr

عند تنفيذ هذا الأمر يوضع العنوان addr الذي سيتم القفز إليه في عداد البرنامج PC فيصبح الأمر الموجود عند هذا العنوان addr هو الأمر الذي عليه الدور في التنفيذ . لاحظ أن هذا الأمر يتكون من ثلاث بايتات واحدة هي شفرة الأمر واثنتان للعنوان addr الذي سيتم القفز إليه . إن القفز باستخدام الأمر JP addr قد يكون إلى الأمام في البرنامج وقد يكون إلى الخلف ، إذا كان القفز إلى الأمام سينتج عن ذلك وجود جزء من البرنامج لن ينفذ على الإطلاق وهو الجزء الذي يقع بين أمر القفز paddr والأمر الذي سيتم القفز إليه . أما إذا كان القفز إلى الخلف فإنه سينتج عن ذلك ما يسمى بالحلقة اللانهائية ولمو المشروط بنوعيها الأمامي والخلفي .

#### 2-6-5 القفز المشروط Conditional jump

كما يوحى الاسم فإنه فى هذا النوع من القفز لن يتم القفز إلا إذا تحقق شرط معين ، أما إذا لم يتحقق هذا الشرط فإن البرنامج يتم تتفيذه فى النتابع الطبيع عن حيث سينفذ الأمر الذى بعد أمر القفز مباشرة . إن شروط القفز توضع دائما على الأعلام التي فى مسجل الحالة SR ، فيمكنك مثلا أن تجعل القفز مشروطا بسان تكون النتيجة صفرا أو تجعله مشروطا بأن تكون النتيجة سالبة و هكذا . حيث أن هناك خمسة أعلام واحد منها و هو علم الحمل النصفى HC لا يستخدم كشرط فى عمليات القفز فإنه يتبقى أربعة أعلام يمكن أن تستخدم فى أو امر القفز المشروط كما بلى :

| ZF=1 | JP Z,addr   | اقفز إذا كانت النتيجة صفرا      |
|------|-------------|---------------------------------|
| ZF=0 | JP NZ, addr | اقفر إذا كانت النتيجة ليست صفرا |
| SF=1 | JP M,addr   | اقفز إذا كانت النتيجة سالبة     |
| SF=0 | JP P,addr   | اقفز إذا كانت النتيجة موجية     |
| CF=1 | JP C,addr   | اقفر إذا كان هذاك حمل           |
| CF=0 | JP NC,addr  | اقفر إذا لم يكن هناك حمل        |
| PF=1 | JP PE,addr  | اقفر إذا كانت الباريتي زوجية    |
| PF=0 | JP PO,addr  | اقفز إذا كانت الباريتي فردية    |
|      |             |                                 |

لاحظ أن عدد هذه الأوامر ثمانية ، إثنان منها لكل علم من الأعلام الأربعة تمثل جميع الحالات التي يمكن أن يكون فيها هذا العلم صفرا أو واحدا . أيضا جميع هذه الأوامر لابد وأن تتكون من ثلاث بايتات واحدة هي شفرة الأمر واثنتان للعنوان الذي سيتم القفز إليه . إن النتيجة التي سيتوقف عليها أمر القفر هي آخر نتيجة تأثرت بها الأعلام ، ولذلك فإنه قبل أن نكتب أي أمر من أوامو القفز المشروط يجب أن ندرس جيدا هل الأمر السابق لأمر القفز يؤتر على الأعلام أم لا .

#### 3-6-5 القفز النسبي Relative jump

هناك أنواع أخرى من القفز متاحة لدى المعالج 280 مثل القفز النسببى والقفز للبرامج الفرعية والعودة منها وسنترك الكلام عن هذه الأنواع حيث سيتم شرحها بالتفصيل في فصول خاصة بذلك .

#### <u>مثال 5-5</u>

اكتب برنامجا يقرأ محتويات البايت E100 باستمرار إلى مالانهاية ثم يختبر هذه المحتويات بحيث إذا كانت صغرا يضع واحدا في المسجل B وإذا كانت سلابة

يضع اثنين في المسجل B وإذا كانت موجبة يضع أربعة في نفس المسجل . شكل (9-4) في الفصل السابق يبين مخطط السير لهذا البرنامج وسنعيد فقط كتابة البرنامج بلغة الأسمبلي الخاصة بالشريحة Z80 كما في شكل (5-9) .

```
E000 E001 E002 LD HL,E100
E003 E004 LD A,00
E005 ADD A,(HL)
E006 E007 E008 JP NZ,E00E
E009 E00A LD B,01
E00B E00C E00D JP E000
E00E E00F E010 JP P,E016
E011 E012 LD B,02
E013 E014 E015 JP E000
E016 E017 LD B,04
E018 E019 E01A JP E000
```

شكل (5-9) برنامج المثال 5-5

### 7-5 مهمة أخرى للأسمبلر

المهمة الوحيدة التي عرفناها للأسمبلر حتى الآن هي مهمـــة تحويـل شـفرات الأسمبلي إلى شفرات ثنائية أو لغة ماكينة ، ولكن لحسن الحظ فإن هنـاك مـهام أخرى يستطيع الأسمبلر القيام بها ومن شأن هذه المهام أن تريح المبرمج وتوفر عليه الكثير من المجهود . جزء 4-7 في الفصل السابق تناول هذه المـهام كمـا تناول أيضا عملية تقسيم أي أمر من أوامر لغة الأسمبلي إلــي أجـزاء مختلفة وكيف يتعرف الأسمبلر على هذه الأجزاء ، لذلك فإننا لن نكرر هذا الجزء هنـا ولكن نحيل القارىء لمراجعته في الفصل السابق مع الأخذ في الاعتبار الفوارق البسيطة بين شفرات الأسمبلي الخاصة بالشريحة 280 والشريحة 8085 .

## 8-5 أوامر الإدخال والإخراج Input Output Instructions

إلى الآن رأينا كيف نبرمج شريحة المعالج وكيف نحرك المعلومات داخلها من مسجل إلى الذاكرة والعكس ، ولكن لم نعرف

حتى الآن كيف نظهر معلومة على شاشة عرض مثلا أيا كان نوع هذه الشاشة ، أو كيف ندخل معلومة إلى المعالج من خلال لوحة مفاتيح على سبيل المثلل . إن لوحة المفاتيح وشاشة العرض يعتبران مثالين من العديد من الأمثلة التي تحتاج إلى عمليات الإخراج والإدخال . حينما يستخدم المعالج للتحكم في أي متغير في عملية صناعية وليكن مثلا درجة الحرارة فإنه لابد من إدخال درجة الحرارة إلى المعالج بعد تهيئتها ووضعها في الصورة المناسبة لذلك ، وكذلك إذا أراد المعالج رفع درجة حرارة العملية الصناعية أو ضرب جرس إنذار فإنه يخرج إشارة معينة على بوابة إخراج تؤخذ وتهيأ في الصورة المناسبة للجهاز الذي ستذهب إليه سواء كان سخانا أو جرسا . إن جميع عمليات الإدخال والإخراج تتم من خلال ما يسمى ببوابات الإدخال والإخراج والتعامل مع هذه البوابات دائما ينقسم إلى قسمين : قسم خاص بالبناء الإلكتروني لهذه البوابات وكيفية توصيلها مسع المعالج وهذا القسم سندرسه بالتفصيل في فصل قادم إن شاء الله ، والقسم الأخر هو كيفية برمجة المعالج للتعامل مع هذه البوابات وهو موضوع دراسنتا في هذا الجزء حيث سندرس الأوامر الخاصة بذلك وسنفترض في دراستنا لهذا الجزء أن القارىء لديه على الأقل بوابة إدخال input port وبوابـة إخـراج output port موصلين في الميكروكومبيوتر الذي يستخدمه في التدريب وكتابة البرامج. .

# 1-8-5 أو امر الأدخال Input Instructions الصورة العامة لأمر الإدخال هي:

IN A, no

محتويات البوابة رقم .no \_\_\_\_ المسجل A

حيث IN هي اختصار لكلمة Input بمعنى ادخل ، وسيقوم هذا الأمر بإدخال المعلومة الموجودة على بوابة الإدخال رقم .no إلى مسجل التراكم A . لاحظ أن عملية الإدخال بهذا الأمر تكون دائما على المسجل A حيث يمكن نقل المعلومة بعد ذلك إلى أي مكان آخر ، هذا الأمر يتكون من اثنين بايت ، واحدة هي شفرة الأمر op code والأخرى هي رقم البوابة التي سيتم التعامل معها . ولذلك فإنه الأمر dlلما أن رقم البوابة يشغل بايت كاملة فإن ذلك يعنى أنه يمكن التعامل مصع 2 على الموابة إدخال تبدأ من البوابة رقم 400 إلى البوابة رقم 574 . انظر شفرة هذا الأمر في جداول الأوامر في نهاية هذا الفصل ، هناك طريقة غير مباشرة للتعامل مع بوابات الإدخال والصورة العامة لها كالتالي :

IN reg,(C)

reg بوابة الأدخال التي رقمها في المسجل C بوابة الأدخال التي رقمها في المسجل الأمر بإدخال المعلومة الموجودة في بوابة الإدخال التي رقمها في المسجل C إلى المسجل reg الذي هو أي مسجل من مسجلات المعالج وهذه ميزة عظيمة لم تكن موجودة في المعالج 8085.

# Output Instruction أو أمر الأخراج المحتورة العامة لأمر الأخراج هي :

OUT no, A المسجل A المسجل البوابة رقم من البوابة رقم من البوابة رقم من البوابة رقم المسجل المعلومة الموجودة في المسجل التي تعنى إخراج التي رقمها من المعلومة الموجودة في المسجل الله المر أيضا يشغل التنين بايت واحدة هي شفرة الأمر والأخرى هي رقم البوابة المراد التعامل معها ، ولذلك فإنه بهذا الأمر يمكن التعامل مسع  $^{8}$  = 25 بوابة إخراج تبدأ من البوابة رقم HOO وتتتهى بالبوابة رقم FFH . الطريقة الغير مباشرة لهذا الأمر هي :

OUT (C), reg

C بوابة الإخراج التي رقمها في المسجل reg يوابة الإخراج التي رقمها في المسجل حيث سيقوم هذا الأمر بإخراج المعلومة الموجودة في المسجل الذي يمثل أي مسجل من مسجلات المعالج إلى بوابة الإخراج التي يوجد رقمها في المسجل C.

#### <u>مثال 5-6</u>

إفترض أن لدينا خط إنتاج في أحد المصانع تعبر عليه المنتجات ، وفيي أثنياء العبور فإن كل منتج يقطع خلية ضوئية فتعطى نبضة كهربية علي خرجها . خرج هذه الخلية موصل على البت رقيم 0 في بوابة الإدخيال رقيم 0H والمطلوب هو كتابة برنامج يعد هذه المنتجات ويخرج العدد على بوابة الإخواج رقم 0H . شكلى (4-11 و 4-12) في الفصل السابق يبينان رسما توضيحيا ومخطط السير لهذا المثال ، أما البرنامج فتمت إعادته كما في شكل (5-10) .

# 9-5 مجموعة أوامر المنطق Logic Instructions

العمليات المنطقية التى يستطيع المعالج Z80 القيام بها هى العمليات XOR, مال MOT, OR, AND وسنكثفى هنا بعرض الصورة العامة لهذه الأوامسر على أن يقوم القارىء بمراجعتها فى جداول الأوامر الملحقة فى آخر الفصل . كما ذكرنا سابقا فإن العمليات المنطقية مثلها مثل العمليات الحسابية لابد وأن يكون المسجل A طرفا فيها كما أن النتيجة توضع فى المسجل .

المسجل B سيكون عداد للمنتج ;LD B,00

المسجل C يحتوى رقم البوابة التي سنخرج عليها ;LD C,00

قراءة بوابة الإدخال إلى المسجل A ,00 ; A

مقارنة الإشارة بصفر ; CP 00

طالما أن الإشارة صفر يستمر في هذه الحلقة ;JP Z,HERE1

عند اختلاف الإشارة عن الصفر يزيد B بواحد B عند اختلاف

حلقة انتظار إلى أن ترجع الإشارة للصفر ;HERE2: IN A,00

**CP 01** 

JP Z,HERE2

يخرج محتويات المسجل B على بوابة الإخراج OUT (C),B; 00

يذهب للبداية ليقرأ نبضة جديدة ;JP HERE1

شكل (5-10) برنامج المثال 5-6

جميع العمليات المنطقية تؤثر على الأعلام ما عدا علمى الحمل والحمل النصفى حيث يكونان دائما صفرا بعد أى عملية منطقية لأن الحمل والحمل النصفى غير معرف مع العمليات المنطقية .

الصورة العامة الأوامر العملية AND هي:

AND reg

AND reg المسجل A → المسجل

AND (HL)

A Ilamet A Ilamet AND (HL)

AND data8

AND data8 المسجل A → المسجل

AND (IX+d)

A المسجل AND (IX+d) المسجل A

AND (IY+d)

A المسجل A المسجل AND (IY+d)

بنفس الطريقة يمكن كتابة الصورة العامة الأوامر OR و XOR كما يلى:

OR reg

OR (HL)

OR data8

OR (IX+d)

OR (IY+d)

XOR reg

XOR (HL)

XOR data8

XOR (IX+d)

XOR (IY+d)

هناك عملية NOT وهي لا تجرى إلا على المسجل A حيث يقلب كل صفر إلى واحد وكل واحد إلى صفر ، والصورة العامة لهذا الأمر هي :

**CPL** 

A  $\longrightarrow$  llamed A  $\longrightarrow$  llamed

هذه العملية تسمى عملية المتمم الأحادى وهناك عملية المتمم التسائى المعرفة كالتالي :

المتمم الثنائي = 1 + المتمم الأحادي وهناك أمر يقوم بعملية المتمم الثنائي وصورته العامة هي :

**NEG** 

A المتمم الثنائي للمسجل A

إن للمتمم الثنائي أهمية خاصة في تحويل عمليات الطرح إلى جمــع كمـا هـو مشروح بالتفصيل في الملحق رقم 1 في نهاية الكتاب .

إلى هنا نكون قد انتهينا من العرض التفصيلي لمعظم أوامر الشريحة 280 على اننا سنعرض هذه الأوامر أولا في صورة مجموعات كما في الأشكال (5-11) إلى 5-20) ثم سنعرض الأومر مرتبة ترتيبا أبجديا كما في شكل (21-5).

| LD     | A, | В, | C, | D, | E, | Н, | L, | (HL),    | (IX+d), | (IY+d),  |
|--------|----|----|----|----|----|----|----|----------|---------|----------|
| A      | 7F | 47 | 4F | 57 | 5F | 67 | 6F | 77       | DD77dd  | FD77dd   |
| В      | 78 | 40 | 48 | 50 | 58 | 60 | 68 | 70       | DD70dd  | FD70dd   |
| С      | 79 | 41 | 49 | 51 | 59 | 61 | 69 | 71       | DD71dd  | FD71dd   |
| D      | 7A | 42 | 4A | 52 | 5A | 62 | 6A | 72       | DD72dd  | FD72dd   |
| E      | 7B | 43 | 4B | 53 | 5B | 63 | 6B | 73       | DD73dd  | FD73dd   |
| H      | 7C | 44 | 4C | 54 | 5C | 64 | 6C | 74       | DD74dd  | FD74dd   |
| L      | 7D | 45 | 4D | 55 | 5D | 65 | 6D | 75       | DD75dd  | FD75dd   |
| data8  | 3E | 06 | 0E | 16 | 1E | 26 | 2E | 36xx     | DD36dd  | FD36ddxx |
|        | XX | <u> </u> | XX      |          |
| (HL)   | 7E | 46 | 4E | 56 | 5E | 66 | 6E |          |         |          |
| (IX+d) | 7E | 46 | 4E | 56 | 5E | 66 | 6E |          |         | *        |
| (IY+d) | 7E | 46 | 4E | 56 | 5E | 66 | 6E |          |         | **       |

<sup>\*</sup> جميع شفرات أو امر هذا المصف تسبقها DD ويعقبها dd مثلها مثل أو امر العمود (IX+d), \*\* جميع شفرات أو امر هذا الصف تسبقها FD ويعقبها dd مثلها مثل أو امر العمود (IY+d), XX يقصد بها البايت الثانية من الأمر وهي Ad

| LD     | BC,   | DE,   | HL,   | SP,   | IX,   | IY,   |
|--------|-------|-------|-------|-------|-------|-------|
| (addr) | ED4B  | ED5B  | 2A    | ED7B  | DD2A  | FD2A  |
|        | adr   | adr   | adr   | adr   | adr   | adr   |
| data16 | 01    | 11    | 21    | 31    | DD21  | FD21  |
|        | dat16 | dat16 | dat16 | dat16 | dat16 | dat16 |

| LD (addr), | BC   | DE   | HL  | SP   | IX   | ΙΥ   |
|------------|------|------|-----|------|------|------|
|            | ED43 | ED53 | 22  | ED73 | DD22 | FD22 |
|            | adr  | adr  | adr | adr  | adr  | adr  |

|      | SR | BC | DE | HL | IX   | IY   |
|------|----|----|----|----|------|------|
| PUSH | F5 | C5 | D5 | E5 | DDE5 | FDE5 |
| POP  | F1 | C1 | D1 | El | DDE1 | FDE1 |

| LD SP, | HL | IX   | IY   |
|--------|----|------|------|
|        | F9 | DDF9 | FDF9 |

شكل (5-11) مجموعة أوامر الانتقال للبروسيسور Z80

| EX DE,HL   | EB   |
|------------|------|
| EX (sp),HL | E3   |
| EX (SP),IX | DDE3 |
| EX (SP),IY | FDE3 |
| EX SR,SR1  | 08   |
| EXX        | D9   |

شكل (5-12) مجموعة أوامر الاستبدال

|        | ADD A, | ADC A, | SUB | SBC A, | INC | DEC | СР |
|--------|--------|--------|-----|--------|-----|-----|----|
| A      | 87     | 8F     | 97  | 9F     | 3C  | 3D  | BF |
| В      | 80     | 88     | 90  | 98     | 04  | 05  | B8 |
| C      | 81     | 89     | 91  | 99     | 0C  | 0D  | В9 |
| D      | 82     | 8A     | 92  | 9A     | 14  | 15  | BA |
| Œ      | 83     | 8B     | 93  | 9B     | 1C  | 1D  | BB |
| H      | 84     | 8C     | 94  | 9C     | 24  | 25  | BC |
| L      | 85     | 8D     | 95  | 9D     | 2C  | 2D  | BD |
| (HL)   | 86     | 8E     | 96  | 9E     | 34  | 35  | BE |
| data8  | C6     | CE     | D6  | DE     |     |     | FE |
|        | XX     | XX     | xx  | xx     |     |     | xx |
| (IX+d) | DD     | DD     | DD  | DD     | DD  | DD  | DD |
|        | 86     | 8E     | 96  | 9E     | 34  | 35  | BE |
|        | dd     | dd     | dd  | dd     | dd  | dd  | dd |
| (IY+d) | FD     | FD     | FD  | FD     | FD  | FD  | FD |
|        | 86     | 8E     | 96  | 9E     | 34  | 35  | BE |
|        | dd     | dd     | dd  | dd     | dd  | dd  | dd |

شكل (5-13) مجموعة أوامر الحساب

|        | AND    | OR     | XOR    |
|--------|--------|--------|--------|
| Α      | A7     | B7     | AF     |
| В      | A0     | B0     | A8     |
| C      | A1     | Bl     | A9     |
| D      | A2     | B2     | AA     |
| E      | A3     | B3     | AB     |
| Н      | A4     | B4     | AC     |
| L      | A5     | B5     | AD     |
| (HL)   | A6     | B6     | AE     |
| data8  | Ебхх   | F6xx   | EExx   |
| (IX+d) | DDA6dd | DDB6dd | DDAEdd |
| (lY+d) | FDA6dd | FDB6dd | FDAEdd |

|   | CPL | NEG  | CCF | SCF |
|---|-----|------|-----|-----|
| Α | 2F  | ED44 | 3F  | 37  |

شكل (5-14) مجموعة أوامر المنطق

|    | ADD IIL, | ADC HL, | SBC HL, | ADD 1X, | ADD IY, | INC | DEC |
|----|----------|---------|---------|---------|---------|-----|-----|
| BC | 09       | ED      | ED      | DD      | FD      | 03  | 0B  |
|    |          | 4A      | 42      | 09      | 09      |     |     |
| DE | 19       | ED      | ED      | DD      | FD      | 13  | 1B  |
|    | +        | 5A      | 52      | 19      | 19      | .   |     |
| HL | 29       | ED      | ED      |         |         | 23  | 2B  |
|    |          | 6A      | 62      |         |         |     |     |
| SP | 39       | ED      | ED      | DD39    | FD      | 33  | 3B  |
|    |          | 7A.     | 72      |         | 39      |     | i   |
| IX |          |         |         | DD      |         | DD  | DD  |
|    |          |         |         | 29      |         | 23  | 2B  |
| IY |          |         |         |         | FD      | FD  | FD  |
|    |          |         |         |         | 29      | 23  | 2B  |

شكل (5-15) أوامر حسابية على أزواج مسجلات

| JP | JP Z | ЛР | JР | Ъ  | JP  | JP | JР | JP |
|----|------|----|----|----|-----|----|----|----|
|    |      | NZ | C  | NC | _ M | P  | PE | PO |
| C3 | CA   | C2 | DA | D2 | FA  | F2 | EA | E2 |
| xx | xx   | xx | xx | xx | xx  | хx | xx | xx |
| xx | xx   | XX | XX | XX | XX  | xx | XX | xx |

| JR   | JR Z | JR NZ | JR C | JR NC |
|------|------|-------|------|-------|
| 18xx | 28xx | 20xx  | 38xx | 30xx  |

| CALL addr    | CDxxxx |
|--------------|--------|
| CALL Z,addr  | CCxxxx |
| CALL NZ,addr | C4xxxx |
| CALL C,addr  | DCxxxx |
| CALL NC,addr | D4xxxx |
| CALL M,addr  | FCxxxx |
| CALL P,addr  | F4xxxx |
| CALL PE,addr | ECxxxx |
| CALL PO,addr | E4xxxx |

| RET    | C9 |
|--------|----|
| RET Z  | C8 |
| RET NZ | C0 |
| RET C  | D8 |
| RET NC | D0 |
| RET M  | F8 |
| RET P  | F0 |
| RET PE | E8 |
| RET PO | E0 |

xxx تمثل اثنين بايت للعنوان الذي سيتم القفز إليه xxx تمثل بايت واحدة للعنوان الذي سيتم القفز إليه في حالة القفز النسبي

شكل (5-16) مجموعة أوامر القفز

الأمر BIT b,sss يجعل علم الصفر يساوى عكس البت رقم b في المسجل أو الذاكرة sss

| Direc  | Ι.  | 1   |             | T 2 | T .         | T   |     | - 1 |
|--------|-----|-----|-------------|-----|-------------|-----|-----|-----|
| BIT    | 0,  | 1,  | 2,          | 3,  | 4,          | 5,  | 6,  | 7,  |
| A      | CB  | CB  | CB          | CB  | CB          | CB  | CB  | CB  |
|        | 47  | 4F  | 57          | 5F  | 67          | 6F  | 77  | 7F  |
| ·B     | CB  | CB  | CB          | CB  | CB          | CB  | CB  | CB  |
|        | 40  | 48  | 50          | 58  | 60          | 68  | 70  | 78  |
| C      | CB  | CB  | CB          | CB  | CB          | CB  | CB  | CB  |
|        | 41  | 49  | 51          | 59  | 61          | 69  | 71  | 79  |
| D      | CB  | CB  | CB          | CB  | CB          | CB  | CB  | СВ  |
|        | 42  | 4A  | 52_         | 5A  | 62          | 6A  | 72  | 7A  |
| E      | CB  | CB  | CB          | CB  | CB          | CB  | CB  | CB  |
|        | 43  | 4B  | 53          | 5B  | 63          | 6B  | 73  | 7B  |
| Н      | CB  | CB  | CB          | CB  | CB          | СВ  | СВ  | СВ  |
|        | 44  | L4C | 54_         | 5C  | 64          | 6C  | 74  | 7C  |
| L      | CB  | CB  | CB          | CB  | CB          | CB  | CB  | CB  |
|        | 45  | 4D  | 55          | 5D  | 65          | 6D  | 75  | 7D  |
| (HL)   | CB  | CB  | CB          | CB  | CB          | CB  | CB  | CB  |
|        | 46  | 4E  | 56          | 5E  | 66          | 6E  | 76  | 7E  |
| (IX+d) | DD  | DD  | DD          | DD  | DD          | DD  | DD  | DD  |
|        | CB  | CB  | CB          | CB  | CB          | CB  | CB  | CB  |
|        | d46 | d4E | <b>d</b> 56 | d5E | d66         | d6E | d76 | d7E |
| (IY+d) | FD  | FD  | FD          | FD  | FD          | FD  | FD  | FD  |
|        | CB  | CB  | CB          | CB  | CB          | CB  | CB  | CB  |
|        | d46 | d4E | d56         | d5E | <b>d</b> 66 | d6E | d76 | d7E |

شكل (5-17) مجموعة اختبار و SET و RESET بت من بثات مسجل أو مكان في الذاكرة

الأمر SET b,sss يجعل البت رقم b في المسجل أو الذاكرة SSS تساوى واحد

|        |            |     |     | 1   |     | _   |     |     |
|--------|------------|-----|-----|-----|-----|-----|-----|-----|
| SET    | 0,         | 1,  | 2,  | 3,  | 4,  | 5,  | 6,  | 7,  |
| A      | CB         | CB  | CB  | CB  | CB  | CB  | CB  | СВ  |
|        | C7         | CF  | D7  | DF  | E7  | EF  | F7  | FF  |
| В      | CB         | CB  | CB  | CB  | CB  | CB  | CB  | CB  |
|        | C0         | C8  | D0  | D8  | E0  | E8  | F0  | F8  |
| C      | CB         | CB  | CB  | CB  | CB  | CB  | CB  | СВ  |
|        | Cl         | C9  | D1  | D9  | E1  | E9  | F1  | F9  |
| D      | CB         | CB  | CB  | CB  | CB  | CB  | CB  | CB  |
|        | C2_        | CA  | D2  | DA  | E2  | EA  | F2  | FA  |
| E      | CB         | СВ  | CB  | CB  | CB  | CB  | СВ  | CB  |
|        | <b>C</b> 3 | CB  | D3  | DB  | E3  | EB  | F3  | FB  |
| H      | CB         | СВ  | CB  | CB  | CB  | CB  | CB  | CB  |
|        | C4         | CC  | D4  | DC  | E4  | EC  | F4  | FC  |
| L      | CB         | CB  | CB  | CB  | CB  | CB  | CB  | CB  |
|        | C5         | CD_ | D5  | DD  | E5  | ED  | F5  | FD  |
| (HL)   | CB         | CB  | CB  | СВ  | CB  | CB  | CB  | СВ  |
|        | C6         | CE  | D6  | DE  | E6  | EE  | F6  | FE  |
| (IX+d) | DD         | DD  | DD  | DD  | DD  | DD  | DD  | DD  |
|        | CB         | СВ  | CB  | CB  | CB  | СВ  | CB  | CB  |
|        | dC6        | dCE | dD6 | dDE | dE6 | dEE | dF6 | dFE |
| (IY+d) | FD         | FD  | FD  | FD  | FD  | FD  | FD  | FD  |
|        | CB         | СВ  | CB  | CB  | CB  | CB  | СВ  | CB  |
|        | dC6        | dCE | dD6 | dDE | dE6 | dEE | dF6 | dFE |

تابع شكل (5-17) مجموعة اختبار و SET و RESET بت من بثات مسجل أو مكان في الذاكرة

الأمر RES b,sss يجعل البت رقم b في المسجل أو الذاكرة sss تساوى صفر

| RES    | 0,  | 1,  | 2,  | 3,  | 4,         | 5,  | 6,         | 7,  |
|--------|-----|-----|-----|-----|------------|-----|------------|-----|
| A      | CB  | СВ  | CB  | CB  | CB         | CB  | CB         | CB  |
|        | 87  | 8F  | 97  | 9F  | A7         | AF  | B7         | BF  |
| В      | CB  | CB  | CB  | CB  | CB         | CB  | CB         | CB  |
|        | 80  | 88  | 90  | 98  | <b>A</b> 0 | A8  | B0         | B8  |
| C      | CB  | CB  | CB  | CB  | CB         | CB  | CB         | CB  |
|        | 81  | 89  | 91  | 99  | Al         | A9  | Bl         | B9  |
| D      | CB  | CB  | CB  | CB  | CB         | CB  | CB         | CB  |
|        | 82  | 8A  | 92  | 9A  | A2         | AA  | _B2        | BA  |
| E      | CB  | СВ  | CB  | CB  | CB         | CB  | CB         | CB  |
|        | 83  | 8B  | 93  | 9B  | A3         | AB  | <b>B</b> 3 | BB  |
| Н      | CB  | CB  | CB  | CB  | .CB        | CB  | CB         | CB  |
|        | 84  | 8C  | 94  | 9C  | A4         | AC  | B4         | BC  |
| L      | CB  | СВ  | CB  | CB  | CB         | CB  | CB         | CB  |
|        | 85  | 8D  | 95  | 9D  | A5         | AD  | B5         | BD  |
| (HL)   | CB  | CB  | CB  | CB  | CB         | CB  | CB         | CB  |
|        | .86 | 8E  | 96  | 9E  | A6         | AE  | B6         | BE  |
| (IX+d) | DD  | DD  | DD  | DD  | DD         | DD  | DD         | DD  |
|        | CB  | CB  | CB  | CB  | CB         | СВ  | CB         | CB  |
|        | d86 | d8E | d96 | d9E | dA6        | dAE | dB6        | dBE |
| (IY+d) | FD  | FD  | FD  | FD  | FD         | FD  | FD         | FD  |
|        | CB  | CB  | CB  | СВ  | CB         | CB  | СВ         | СВ  |
|        | d86 | d8E | d96 | d9E | dA6        | dAE | dB6        | dBE |

تابع شكل (5-17) مجموعة اختبار و SET و RESET بت من بتات مسجل أو مكان في الذاكرة

|        | RLC | RRC | RL  | RR  | SLA | SRA | SRL |
|--------|-----|-----|-----|-----|-----|-----|-----|
| A      | CB  | СВ  | СВ  | CB  | CB  | СВ  | CB  |
|        | 07  | 0F  | 17  | 1F  | 27  | 2F  | 3F  |
| В      | CB  | CB  | CB  | CB  | CB  | СВ  | СВ  |
|        | 00  | 08  | 10  | 18  | 20  | 28  | 38  |
| C      | CB  |
|        | 01  | 09  | 11  | 19  | 21  | 29  | 39  |
| D      | CB  |
|        | 02  | OA_ | 12  | 1A  | 22  | 2A  | 3A  |
| Œ      | CB  | CB  | CB  | CB  | CB  | CB  | СВ  |
|        | 03  | 0B  | 13  | 1B  | 23  | 2B  | 3B  |
| H      | CB  | CB  | CB  | CB  | СВ  | CB  | CB  |
|        | 04  | OC_ | 14  | 1C  | 24  | 2C  | 3C  |
| L      | CB  |
|        | 05  | OD_ | 15  | 1D  | 25  | 2D  | 3D  |
| (HL)   | CB  |
|        | 06  | 0E  | 16  | 1E  | 26  | 2E  | 3E  |
| (IX+d) | DD  |
|        | CB  |
|        | d06 | d0E | d16 | d1E | d26 | d2E | d3E |
| (IY+d) | FD  |
|        | CB  |
|        | d06 | d0E | d16 | d1E | d26 | d2E | d3E |

## أوامر خاصة بإزاحة أو دوران المسجل A فقط

|     |     |      | 711  |  |
|-----|-----|------|------|--|
| RRA | RLA | RRCA | RLCA |  |
| 1F  | 17  | 0F   | 07   |  |

شكل (5-18) مجموعة أوامر الأزاحة والدوران

| II.     | I A   | , В, | C,   | D,   | E,   | H,   | L,   |
|---------|-------|------|------|------|------|------|------|
| Port No | . D8x | ζ    |      |      |      |      |      |
| (C      | ) ED7 | ED40 | ED48 | ED50 | ED58 | ED60 | ED68 |

| OUT | Port No., | (C), |
|-----|-----------|------|
| A   | D3xx      | ED79 |
| В   |           | ED41 |
| С   |           | ED49 |
| D   |           | ED51 |
| Е   | ****      | ED59 |
| Н   |           | ED61 |
| L   |           | ED69 |

شكل (5-19) أوامر الإدخال والإخراج

| لا تعمل شيء No Operation, NOP        | 00         |
|--------------------------------------|------------|
| توقف HALT                            | 76         |
| اخماد المقاطعة Disable Interrupt, DI | <b>F</b> 3 |
| تتشيط المقاطعة Enable Interrupt, EI  | FB         |
| تتشيط حالة المقاطعة رقم صفر IMO      | ED46       |
| تتقبيط حالة المقاطعة رقم صفر IM1     | ED56       |
| تتشيط حالة المقاطعة رقم صفر IM2      | ED5E       |

شكل (5-20) مجموعة أوامر متفرقة

كانت هذه بعض أهم مجموعات الأوامر للمعالج Z80 والشائعة الاستخدام . شكل (Zi-5) يحتوى جميع أوامر الشريحة مرتبة ترتيبا أبجديا مع نبذة عن ما يعملك كل أمر وعدد نبضات التزامن التي يأخذها (ن #) لكى يتم إحضاره من الذاكرة وتنفيذه والأعلام التي تتأثر بكل أمر وكذلك شفرة كل أمر حيث من هذه الشفرة يمكن استنتاج عدد بايتات الأمر و انظر الملاحظات الخاصة بشفرة الأوامر في يمكن الشكل .

| شفرة الأسمبلى            | الأعلام        | #       | شفرة الأمر  | وظيفة الأمر                   |
|--------------------------|----------------|---------|-------------|-------------------------------|
|                          | المتأثرة       | ن       |             |                               |
| ADC A,reg                | ZSP CY HC      | 4       | 10001sss    | A < A+CY+ reg                 |
| ADC A,(HL)               | ZSP CY HC      | 7       | 8E          | $A \leftarrow A+CY+(HL)$      |
| ADC A,data8              | ZSP CY HC      | 7       | CE data8    | A← A+CY+data8                 |
| ADC A,(IY+d)             | ZSP CY HC      | 19      | FD 8E dd    | $A \leftarrow A+CY+(IY+d)$    |
| ADC A,(IX+d)             | ZSP CY HC      | 19      | DD 8E dd    | $A \leftarrow A+CY+(IX+d)$    |
| ADC HL,rp                | CY-            | 15      | ED 01rp1010 | HL ← HL+CY+rp                 |
| ADD A,reg                | ZSP CY HC      | 4       | 10000sss    | $A \leftarrow A + Reg$        |
| ADD A,(HL)               | ZSP CY HC      | 7       | 86          | $A \leftarrow A + (HL)$       |
| ADD A,data8              | ZSP CY HC      | 7       | C6 data8    | A ← A+data8                   |
| ADD A,(IY+d)             | ZSP CY HC      | 19      | FD 88 dd    | $A \leftarrow A + (IY + d)$   |
| ADD A,(IX+d)             | ZSP CY HC      | 19      | DD 86 dd    | A← A+ (IX+d)                  |
| ADD HL,rp                | CY-            | 11      | 00rp1001    | HL ← HL+rp                    |
| ADD IY,rp                | CY -           | 15      | FD 00rp1001 | $IX \leftarrow IY + rp$       |
| ADD IX,rp                | CY-            | 15      | DD 00rp1001 | $IX \leftarrow IX + rp$       |
| AND reg                  | ZSP00          | 4       | 10100xxx    | A AND reg                     |
| AND (HL)                 | ZS P 0 0       | 7       | A6          | $A \leftarrow A AND (HL)$     |
| AND data8                | ZS P 0 0       | 7       | E6 data8    | A                             |
| AND (IY+d)               | ZS P 0 0       | 19      | FD A6 dd    | $A \leftarrow A AND (IY+d)$   |
| AND (IX+d)               | ZS P 0 0       | 19      | DD A6 dd    | $A \leftarrow AND(IX+d)$      |
| Sand Property of Company |                |         | 200,000,000 |                               |
| BIT b,reg                | Z              | 9       | CB 01bbbsss | عكس البت b في ZF ← reg        |
| BIT b,(HL)               | Z              | 12      | CB 01bbb110 | عكس البت b في (HL) —≥ ZF      |
| BIT b,(IY+d)             | Z              | 20      | FD CB dd    | عكس البت b في (IY+D) حكس      |
|                          | <u> </u>       |         | 01bbb110    |                               |
| BIT b,(IX+d)             | Z              | 20      | DD CB dd    | عكس البت b في (IX+D) حكس البت |
|                          | 7.0440 S.040 S | and the | 01bbb110    |                               |
| CALL addr                |                | 17      | CD addr     | لداء غير مشروط لبرنامج فرعى   |
| CALL C,addr              |                | 10/17   | DC addr     | نداء مشروط بعلم الحمل= [      |
| CALL M,addr              |                | 10/17   | FC addr     | نداء مشروط بعلم إشارة=1       |
| CALL NC,addr             |                |         | D4 addr     | نداء مشروط بعلم الحمل-0       |
| CALL NZ,addr             |                |         | C4 addr     | لداء مشروط بعلم الصفر =0      |
| CALL P,addr              |                |         | F4 addr     | لداء مشروط بعلم إشارة=0       |
| CALL PE,addr             |                |         | EC addr     | نداء مشروط بعلم باریتی-1      |
| CALL PO,addr             |                |         | E4 addr .   | نداء مشروط بعلم باریتی=()     |
| CALL Z,addr              |                | _       | CC addr     | لداء مشروط بعلم الصفر = 1     |
| CCF                      | CY HC          | 4       | 3F          | اعكس علم الحمل                |
| CP reg                   | ZSP CY HC      | 4       | 10111sss    | مقارنة A - reg                |
| CP (HL)                  | ZSP CY HC      | 7       | BE          | مقارنة (.III) - A             |
| CP const                 | ZSP CY HC      | 7       | FE data8    | مقارنة A - const              |
| CP (IY+d)                | ZSP CY HC      | 19      | FD BE data8 | مقارنة (IY+d) - A             |
| CP (IX+d)                | ZSP CY HC      | 19      | DD BE data8 | مقارنة (IX+d) - ۸             |
| CPL                      |                | 4       | 2F          | اعكس المسجل A                 |

| CPI          | ZSP CY HC  | 16      | ED A1       | مقارنة (١١١)-٨                                                                                                            |
|--------------|------------|---------|-------------|---------------------------------------------------------------------------------------------------------------------------|
| CFI          | ZASI CT HC | 10      | EDAI        | BC← BC-1 .HL← HL+                                                                                                         |
| CPIR         | ZSP CY HC  | 21/16   | ED B1       |                                                                                                                           |
| CPD          | ZSP CY HC  |         | ED A9       | کرر CPI إلى CPI الى                                                                                                       |
| CPD          | ZSP CY HC  | 16      | ED VA       | مقارنة (١١١) ٨-٨                                                                                                          |
| ann          | 200 611116 | 121/12  |             | BC← BC-1 .HL← HL-                                                                                                         |
| CPDR         | ZSP CY HC  | 21/16   | ED B9       | کرر (CPT إلى 3C=0                                                                                                         |
| DAA          | ZSP CY HC  | 4       | 27          | حول المركم للنظام العشرى                                                                                                  |
| DEC reg      | ZSP - HC   | 4       | 00ddd101    | reg ← reg -                                                                                                               |
| DEC (III.)   | ZSP HC     | 7       | 35          | (HL) ← (HL) - 1                                                                                                           |
| DEC (IY+d)   | ZSP HC     | 19      | FD 35 data8 | $(IX+d) \leftarrow (IY+d)$                                                                                                |
| DEC (IX+d)   | ZSP - HC   | 19      | DD 35 data8 | $(lX+d) \leftarrow (lX+d)$                                                                                                |
| Dl           |            | 4       | F3          | اهمل المقاطعة () -> ١١٠                                                                                                   |
| DEC гр       |            | 6       | 00гр1011    | rp ← rp - l                                                                                                               |
| DEC IY       |            | 10      | FD 213      | IX < IY - I                                                                                                               |
| DEC IX       |            | 10      | DD 2B       | IX ← IX - 1                                                                                                               |
| DJNZ ddd     |            | 8/13    | 10 ddd      | قفز بمقدار ddd) و إنقاص [1                                                                                                |
|              |            |         |             | بمقدار ۱ إلى أن يصبح ()=(ا                                                                                                |
|              |            | 1       |             |                                                                                                                           |
| EI           |            | 4       | FB:         | اسمح بالمقاطعة ا                                                                                                          |
| EX DE,HL     |            | 4       | EB          | IIL ←>DE                                                                                                                  |
| EX AF,AF1    |            | 4       | 08          | PSW1 ←→ PSW                                                                                                               |
| EXX          |            | 4       | D9          | BCDEIILI ← → BCDEIII.                                                                                                     |
| EX (SP),HL   |            | 19      | 13          | $(SP+1) \xrightarrow{\longrightarrow} H$ $(SP) \xrightarrow{\longrightarrow} L$                                           |
| EX (SP),IX   |            | 23      | FD E3       | $(SP+1) \longrightarrow IV/II$                                                                                            |
| 1.7 (51 ),17 |            | 2.5     | 131,        | $(SP) \xrightarrow{(SI+1)} IY/I.$                                                                                         |
| EX (SP),IX   |            | 23      | DD E3       | $\begin{array}{c} (SP+1) \longrightarrow IY/II \\ (SP) \longrightarrow IY/IL \\ (SP+1) \longrightarrow IX/II \end{array}$ |
| , ( ),       | 1          | -       |             | $(SP) \longrightarrow IX/L$                                                                                               |
|              |            | 1       |             |                                                                                                                           |
| HALT         |            | 4       | 76          | أوقف تنفيذ البرنامج                                                                                                       |
| IM ()        |            | 8       | ED 46       | حالة المقاطعة صغر                                                                                                         |
| IM i         |            | 8       | ED 56       | حالة المقاطعة واحد                                                                                                        |
| IM 2         |            | 8       | ED 5E       | حالة المقاطعة اثنين                                                                                                       |
| IN Λ,(no.)   |            | 11      | DB no8      | اللبوابة رقم .١١٥ ܐ ٨                                                                                                     |
| IN reg,(C)   |            | 12      | ED 01ddd000 | البوابة (C) — reg                                                                                                         |
| INI          |            | 16      | ED A2       | port (C) HL)                                                                                                              |
|              |            |         |             | B-1 <del>&gt;</del> B                                                                                                     |
|              |            |         |             | HL ← 111.+1                                                                                                               |
| INIR         |            | 16/21   | ED B2       | کرر INI إلى أن B=0                                                                                                        |
| IND          |            | 16      | ED AA       | $port(C) \longrightarrow (HIL)$                                                                                           |
|              | 1          |         |             | $B-1 \longrightarrow B$                                                                                                   |
|              |            | <b></b> |             | HL HL-I                                                                                                                   |
| INDR         |            | +       | ED BA       | کرر IND إلى أن0=B                                                                                                         |
| INC reg      | ZSP-HC     | 4       | 00444100    | reg ← reg + 1                                                                                                             |
| INC (HL)     | ZSP-HC     | 7       | 34          | (HL)+1 (HL)                                                                                                               |
| INC (IY+d)   | ZSP-HC     | 19      | FD 34 dd    | $(IY+d) \leftarrow (IY+d)+1$                                                                                              |
| INC (IX+d)   | ZSP-HC     | 19      | DD 34 dd    | $(IX+d) \leftarrow (IX+d)+1$                                                                                              |

| INC IY                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | DIO             |                | -           | 000011         |                             |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|----------------|-------------|----------------|-----------------------------|
| NC   NC   NC   NC   NC   NC   NC   NC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | INC rp          |                |             | 00xx0011       | m ← m+1                     |
| IP addr         10         C3 addr         Bett, Low adolp is it, and a section is                    |                 |                |             |                |                             |
| IP eddr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                 |                |             | DD 23          | IX \ IX+I                   |
| IP (HL)         4         E9         HL ني علوان أي الإرسال الله         iši (إلى علوان أي الإرسال الله         IP (IX)         8         DD B9         IX رقال علوان أي IX (إلى الله إلى الله الله إلى الله الله الله الله الله الله الله ال                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                 |                |             |                |                             |
| IP (IX)         8         DD E9         IX رغا علوان أي علوان أي الإن علوان أي علوان أ                   |                 |                | 4           | E9             |                             |
| JP (TY)       8       FD E9       TY نفر الحيار العاق المنافر العاق المنافر العاق المنافر العاق المنافر العاق المنافر العاق ال                           |                 |                | 8           | DD E9          |                             |
| IP Z,addr         10         CA addr         1 — المسافر وطا يعلم الصفر و المعلم ا                   |                 |                |             |                |                             |
| JP NZ,addr         10         C2 addr         0-jid alma alma alma alma alma alma alma alm                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | JP Z,addr       |                | 10          | CA addr        |                             |
| IP C,addr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | JP NZ,addr      |                | 10          | C2 addr        |                             |
| IP NC,addr         10         D2 addr         0-لمحالط الحمل الوقع المحالث الاحتى المحالط                    | JP C,addr       |                | 10          | DA addr        |                             |
| JP PO,addr         10         E2 addr         0-يند مشروط بطم باريذي - 10         EA addr         1-يند مشروط بطم باريذي - 10         F2 addr         1-يند مشروط بطم باريذي - 10         F2 addr         0-يند مشروط بطم اشارة - 10         F3 addr         1-yik addr         10         70         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10 <t< td=""><td>JP NC,addr</td><td></td><td>10</td><td>D2 addr</td><td></td></t<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | JP NC,addr      |                | 10          | D2 addr        |                             |
| JP PE,addr         10 EA addr         1 - القر مشروط بعلم إداريتي   P P,addr         10 F2 addr         0 - القر مشروط المعلم الشارة   P M,addr         10 F2 addr         0 -   P M,addr         10 FA addr         1 -   P M,addr         2 -   P M,addr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                 |                | 10          | E2 addr        |                             |
| JP P,addr         الله مشروط بسلم اشارة السارة السار |                 |                | 10          |                |                             |
| JP M,addr         اقار مشروط بعلم اشارة الله الله الله الله الله الله الله الل                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                 |                |             |                |                             |
| JR dd       ان الا الا الا الا الا الا الا الا الا ا                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                 |                |             |                |                             |
| JR Z,dd        7/12       28 dd       Z=1 مشروط Z=0 كان الله كان الل                                              |                 |                |             |                |                             |
| JR NZ,dd       7/12       20 dd       Z=0 مشروط 20       JR C,dd       7/12       38 dd       CY=1 فقز لسبي مشروط 17/12       38 dd       CY=1 38 dd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | JR Z,dd         |                | 7/12        | 28 dd          |                             |
| JR C,dd 7/12 38 dd CY=1 قَلْوُ لَسَنِي مُشُورُ وَلِمُ 17 NC,dd 7/12 30 dd CY=0 قَلْوُ لَسَنِي مُشُورُ وَلِمُ 17 NC,dd 7/12 30 dd CY=0 كال الله الله الله الله الله الله الله                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                 |                |             | 20 dd          |                             |
| JR NC,dd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                 |                | 7/12        | 38 dd          |                             |
| LD reg1,reg2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                 |                |             | 30 dd          |                             |
| LD reg1,reg2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                 | Patroto attore | minary Pigo |                |                             |
| LD (FIL),reg     7    01110sss   (FIL)     reg     LD reg,data8     7    11ddd110 data8   reg   data8     LD reg,(IY+d)     19    FD 01ddd110 dd   reg   (IY+d)     LD reg,(IX+d)     19    DD 01ddd110 dd   reg   (IX+d)     LD (IY+d),reg     19    FD 01110sss dd   (IY+d)   reg     LD (IX+d),reg     19    DD 01110sss dd   (IX+d)   reg     LD (IIL),data8     10    36 data8   (HL)   data8     LD (IY+d),data8     19    FD 36 dd data8   (IY+d)   data8     LD (IX+d),data8     19    DD 36 dd data8   (IX+d)   data8     LD (IX+d),data8     13    3A addr   A   (addr)   A     LD (addr),A     13    32 addr   (addr)   A     LD (addr),BC     20    ED 43 addr   addr   C addr+1   B     LD (addr),HL     20    ED 53 addr   addr   L addr+1   H     LD (addr),IX     20    DD 22 addr   addr   IX/L addr+1   IX/H     LD (addr),SP     20    ED 73 addr   addr   SP/L addr+1   SP/H     LD (A,(BC)     7    0A   A   (BC)     LD (A,(DE),A     7    12   A   (DE)     LD (A,II     9    ED 57   A   I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | LD reg1,reg2    |                | 4           | 01dddsss       | $reg2 \longrightarrow reg1$ |
| LD (FIL),rcg     7    01110sss   (HL) ← reg     LD reg,data8     7    11ddd110 data8   reg ← data8     LD reg,(IY+d)     19    FD 01ddd110 dd   reg ← (IY+d)     LD reg,(IX+d)     19    DD 01ddd110 dd   reg ← (IX+d)     LD (IY+d),reg     19    FD 01110sss dd   (IY+d) ← reg     LD (IX+d),reg     19    DD 01110sss dd   (IX+d) ← reg     LD (IIL),data8     10    36 data8   (HL) ← data8     LD (IY+d),data8     19    FD 36 dd data8   (IY+d) ← data8     LD (IX+d),data8     19    DD 36 dd data8   (IX+d) ← data8     LD A,(addr)     13    3A addr   A ← (addr) ← A     LD (addr),A     13    32 addr   (addr) ← A     LD (addr),BC     20    ED 43 addr   addr ← C addr+1 ← B     LD (addr),HL     20    ED 53 addr   addr ← I addr+1 ← H     LD (addr),HL     20    DD 22 addr   addr ← IX/L addr+1 ← IX/H     LD (addr),SP     20    ED 73 addr   addr ← SP/L addr+1 ← IY/H     LD (addr),SP     20    ED 73 addr   addr ← SP/L addr+1 ← SP/H     LD A,(BC)     7    1A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | LD reg,(HL)     |                |             | 01ddd110       |                             |
| LD reg,(IY+d)        19       FD 01ddd110 dd       reg ← (IY+d)         LD reg,(IX+d)        19       DD 01ddd110 dd       reg ← (IX+d)         LD (IY+d),reg        19       FD 01110sss dd       (IY+d) ← reg         LD (IX+d),reg        19       DD 01110sss dd       (IX+d) ← reg         LD (III),data8        10       36 data8       (IY+d) ← data8         LD (IY+d),data8        19       FD 36 dd data8       (IY+d) ← data8         LD (IX+d),data8        19       DD 36 dd data8       (IX+d) ← data8         LD (IX+d),data8        13       3A addr       A ← (addr)         LD (addr),data8        13       32 addr       (addr) ← A         LD (addr),BC        13       32 addr       (addr) ← C addr+1 ← B         LD (addr),BC        20       ED 43 addr       addr ← C addr+1 ← B         LD (addr),BC        20       ED 53 addr       addr ← E addr+1 ← D         LD (addr),HL        20       ED 53 addr       addr ← IX/L addr+1 ← IX/H         LD (addr),IY                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                 |                |             |                |                             |
| LD reg,(IX+d)        19       DD 01ddd110 dd       reg ← (IX+d)         LD (IY+d),reg        19       FD 01110sss dd       (IY+d) ← reg         LD (IX+d),reg        19       DD 01110sss dd       (IX+d) ← reg         LD (IIL),data8        19       FD 36 dd data8       (IY+d) ← data8         LD (IX+d),data8        19       FD 36 dd data8       (IX+d) ← data8         LD (IX+d),data8        19       DD 36 dd data8       (IX+d) ← data8         LD (IX+d),data8        19       DD 36 dd data8       (IX+d) ← data8         LD (addr),data8        13       3A addr       A ← (addr)         LD (addr),BC        20       ED 43 addr       (addr) ← C addr+1 ← B         LD (addr),BC        20       ED 53 addr       addr ← C addr+1 ← B         LD (addr),HL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | LD reg,data8    |                | 7_          | 11ddd110 data8 |                             |
| LD (IY+d),reg        19       FD 01110sss dd       (IY+d) ← reg         LD (IX+d),reg        19       DD 01110sss dd       (IX+d) ← reg         LD (IIL),data8        10       36 data8       (HL) ← data8         LD (IY+d),data8        19       FD 36 dd data8       (IX+d) ← data8         LD (IX+d),data8        19       DD 36 dd data8       (IX+d) ← data8         LD (Addr),data8        13       3A addr       A ← (addr)       A ← (addr)         LD (addr),A        13       32 addr       (addr) ← A       A ← (addr)       A         LD (addr),BC        20       ED 43 addr       addr ← C addr+1 ← B       B       LD (addr),DE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | LD reg,(IY+d)   |                | 19          | FD 01ddd110 dd | $reg \leftarrow (IY+d)$     |
| LD (IX+d),reg        19       DD 01110sss dd       (IX+d) ← reg         LD (IIL),data8       10       36 data8       (HL) ← data8         LD (IY+d),data8       19       FD 36 dd data8       (IY+d) ← data8         LD (IX+d),data8       19       DD 36 dd data8       (IX+d) ← data8         LD A,(addr)        13       3A addr       A ← (addr)         LD (addr),A        13       32 addr       (addr) ← A         LD (addr),BC        20       ED 43 addr       addr ← C addr+1 ← B         LD (addr),DE        20       ED 53 addr       addr ← E addr+1 ← D         LD (addr),HL        20       22 addr       addr ← IX/L addr+1 ← H         LD (addr),HL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                 |                | 19          | DD 01ddd110 dd | $reg \leftarrow (IX+d)$     |
| LD (IIL),data8 19 FD 36 dd data8 (IIL) ← data8  LD (IY+d),data8 19 FD 36 dd data8 (IY+d) ← data8  LD (IX+d),data8 19 DD 36 dd data8 (IX+d) ← data8  LD A,(addr) 13 3A addr A ← (addr)  LD (addr),A 20 ED 43 addr addr ← C addr+1 ← B  LD (addr),DE 20 ED 53 addr addr ← E addr+1 ← D  LD (addr),HL 20 Z2 addr addr ← IX/L addr+1 ← H  LD (addr),IX 20 FD 22 addr addr ← IX/L addr+1 ← IX/H  LD (addr),IY 20 ED 73 addr addr ← SP/L addr+1 ← SP/H  LD (addr),SP 20 ED 73 addr addr ← SP/L addr+1 ← SP/H  LD (addr),SP 7 0A A ← (BC)  LD (A,(DE) 7 1A A ← (DE)  LD (BC),A 7 12 A → (DE)  LD (DE),A 9 ED 57 A ← I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | LD (IY+d),reg   |                | 19          |                |                             |
| LD (IY+d),data8        19       FD 36 dd data8       (IY+d) ← data8         LD (IX+d),data8        19       DD 36 dd data8       (IX+d) ← data8         LD A,(addr)        13       3A addr       A ← (addr)         LD (addr),A        13       32 addr       (addr) ← C addr+1 ← B         LD (addr),BC        20       ED 43 addr       addr ← C addr+1 ← B         LD (addr),DE        20       ED 53 addr       addr ← E addr+1 ← D         LD (addr),HL        20       22 addr       addr ← E addr+1 ← H         LD (addr),HL        20       DD 22 addr       addr ← IX/L addr+1 ← IX/H         LD (addr),IX        20       FD 22 addr       addr ← IX/L addr+1 ← IX/H         LD (addr),IY        20       ED 73 addr       addr ← SP/L addr+1 ← SP/H         LD A,(BC)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | LD (IX+d),reg   |                | 19          | DD 01110sss dd | (IX+d) ← reg                |
| LD (IY+d),data8        19       FD 36 dd data8       (IY+d) ← data8         LD (IX+d),data8       19       DD 36 dd data8       (IX+d) ← data8         LD A,(addr)        13       3A addr       A ← (addr)         LD (addr),A        20       ED 43 addr       addr ← C addr+1 ← B         LD (addr),BC        20       ED 53 addr       addr ← E addr+1 ← D         LD (addr),HL        20       22 addr       addr ← Ix/L addr+1 ← H         LD (addr),IX        20       DD 22 addr       addr ← IX/L addr+1 ← IX/H         I.D (addr),IY        20       FD 22 addr       addr ← IX/L addr+1 ← IY/H         LD (addr),SP        20       ED 73 addr       addr ← SP/L addr+1 ← SP/H         LD A,(BC)        7       0A       A ← (BC)         LD A,(DE)        7       1A       A ← (DE)         LD (BC),A        7       12       A → (DE)         LD A,I        9       ED 57       A ← I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | LD (I·IL),data8 |                | 10          | 36 data8       | (HL) ← data8                |
| LD A,(addr)        13       3A addr       A ← (addr)         LD (addr),A        13       32 addr       (addr) ← A         LD (addr),BC        20       ED 43 addr       addr ← C addr+1 ← B         LD (addr),DE        20       ED 53 addr       addr ← E addr+1 ← D         LD (addr),HL        20       22 addr       addr ← IX/L addr+1 ← H         LD (addr),IX        20       DD 22 addr       addr ← IX/L addr+1 ← IX/H         LD (addr),IY        20       FD 22 addr       addr ← IX/L addr+1 ← IY/H         LD (addr),SP        20       ED 73 addr       addr ← SP/L addr+1 ← SP/H         LD A,(BC)        7       0A       A ← (BC)         LD A,(DE)        7       1A       A ← (DE)         LD (BC),A        7       12       A → (DE)         LD A,I        9       ED 57       A ← I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | LD (IY+d),data8 |                | 19          | FD 36 dd data8 |                             |
| $ \begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | LD (IX+d),data8 |                | 19          | DD 36 dd data8 | (IX+d) ← data8              |
| LD (addr),BC        20       ED 43 addr       addr← C addr+1← B         LD (addr),DE        20       ED 53 addr       addr← E addr+1← D         LD (addr),HL        20       22 addr       addr← L addr+1← H         LD (addr),IX        20       DD 22 addr       addr← IX/L addr+1← IX/H         LD (addr),IY        20       FD 22 addr       addr← IY/L addr+1← IY/H         LD (addr),SP        20       ED 73 addr       addr← SP/L addr+1← SP/H         LD Λ,(BC)        7       0A       A ← (BC)         LD Λ,(DE)        7       1A       A ← (BC)         LD (BC),Λ        7       02       Λ → (BC)         LD (DE),Λ        7       12       Λ → (DE)         LD Λ,I        9       ED 57       A ← I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | LD A,(addr)     |                | 13          | 3A addr        | A ← (addr)                  |
| LD (addr),DE        20       ED 53 addr       addr ← E addr+1 ← D         LD (addr),HL        20       22 addr       addr ← L addr+1 ← H         LD (addr),IX        20       DD 22 addr       addr ← IX/L addr+1 ← IX/H         LD (addr),IY        20       FD 22 addr       addr ← IY/L addr+1 ← IY/H         LD (addr),SP        20       ED 73 addr       addr ← SP/L addr+1 ← SP/H         LD Λ,(BC)        7       0A       A ← (BC)         LD Λ,(DE)        7       1A       A ← (DE)         LD (BC),Λ        7       12       A → (DE)         LD Λ,I        9       ED 57       A ← I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | LD (addr),A     |                | 13          | 32 addr        | (addr) ← A                  |
| LD (addr),DE        20       ED 53 addr       addr ← E addr+1 ← D         LD (addr),HL        20       22 addr       addr ← L addr+1 ← H         LD (addr),IX        20       DD 22 addr       addr ← IX/L addr+1 ← IX/H         LD (addr),IY        20       FD 22 addr       addr ← IY/L addr+1 ← IY/H         LD (addr),SP        20       ED 73 addr       addr ← SP/L addr+1 ← SP/H         LD Λ,(BC)        7       0A       A ← (BC)         LD Λ,(DE)        7       1A       A ← (DE)         LD (BC),Λ        7       12       A → (DE)         LD Λ,I        9       ED 57       A ← I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                 |                | 20          | ED 43 addr     | addr←C addr+1←B             |
| $ \begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                 |                | 20          | ED 53 addr     |                             |
| LD (addr),IX 20 DD 22 addr addr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                 |                |             |                |                             |
| I.D (addr),IY        20       FD 22 addr       addr ← IY/L addr+1 ← IY/H         I.D (addr),SP        20       ED 73 addr       addr ← SP/L addr+1 ← SP/H         I.D Λ,(BC)        7       0A       A ← (BC)         I.D Λ,(DE)        7       1A       A ← (DE)         I.D (BC),Λ        7       12       A → (DE)         I.D (DE),Λ        9       ED 57       A ← I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                 |                | 77          |                |                             |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                 |                |             |                |                             |
| LD Λ,(BC)        7       0A       A ← (BC)         LD Λ,(DE)        7       1A       A ← (DE)         LD (BC),Λ        7       02       Λ → (BC)         LD (DE),Λ        7       12       Λ → (DE)         LD Λ,I        9       ED 57       Λ ← I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                 |                |             |                |                             |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                 |                | 7           |                |                             |
| LD (BC), $\Lambda$ 7 02 $\Lambda \longrightarrow$ (BC)<br>LD (DE), $\Lambda$ 7 12 $\Lambda \longrightarrow$ (DE)<br>LD $\Lambda$ ,I 9 ED 57 $\Lambda \longrightarrow$ I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                 |                |             |                |                             |
| LD (DE), $\Lambda$ 7 12 A $\longrightarrow$ (DE)<br>LD $\Lambda$ ,I 9 ED 57 A $\longleftarrow$ I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                 |                |             |                |                             |
| LD ∧,I 9 ED 57 A ← I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                 |                |             |                |                             |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                 |                |             |                |                             |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                 |                |             |                |                             |

| LD A,R        |                      | 9         | ED 5F            | ∧ ← R                                                                        |
|---------------|----------------------|-----------|------------------|------------------------------------------------------------------------------|
| LD R,A        |                      | 9         | ED 4F            | $R \longleftarrow A$                                                         |
| LD rp,data16  |                      | 10        | 00rp0001 data16  | rp←— data16                                                                  |
| LID IX,data16 |                      | 14        | DD 21 data16     | IX ← data16                                                                  |
| LD rp,(addr)  |                      | 20        | ED 01rp1011 addr | $(addr+1) \longrightarrow B (addr) \longrightarrow C$                        |
| LD HL,(addr)  |                      | 16        | 2A addr          | $(addr+1) \rightarrow H (addr) \rightarrow L$                                |
| LD IX,(addr)  |                      | 20        | DD 2A addr       | (addr) → IX/1.                                                               |
|               |                      |           |                  | IX/H <del>&lt; (addr+1),</del>                                               |
| LD IY,(addr)  |                      | 20        | FD 2A addr       | $(addr) \longrightarrow IY/L$                                                |
|               |                      |           |                  | IY/H ← (addr+1),                                                             |
| LD SP.HL      |                      | 16        | F9               | $HL \longrightarrow SP$                                                      |
| LD SP,IX      |                      | 10        | DD 1:0           | SP ←—IX                                                                      |
| LID SP,IY     |                      | 10        | FD F9            | SP ←—IY                                                                      |
| LD            | ZSP                  | 16        | ED A0            | $DE \leftarrow DE+1 (HL) \rightarrow (DE)$                                   |
|               |                      |           |                  | HI <del>C</del> HL+1                                                         |
|               |                      |           |                  | BC ← BC-1                                                                    |
| LDIR          | ZSP                  | 21/16     | ED BO            | نفس الأمر السابق إلى BC=0                                                    |
|               |                      |           |                  | , G, G,                                                                      |
| LDD           | ZSP                  | 16        | ED AB            | $DE \leftarrow DE-1 (HL) \rightarrow (DE)$                                   |
| 1,1,51,5      | 7.01                 | ''        | I D AB           | BC ←BC-1 HL← HL-1                                                            |
| LDDR          | ZSP                  | 21/16     | ED BB            | نفس الأمر السابق إلى BC=0                                                    |
| 1313131       |                      |           |                  |                                                                              |
| NEG           | ZSP                  | 8         | ED 44            | المتمم الثناني ل ۸ —> ۸                                                      |
| NOP           |                      | 4         | 00               | No operation لا تعمل شيئا                                                    |
| •             |                      |           |                  |                                                                              |
| OR reg        | ZSP0 0               | 4         | 10110sss         | A ← A OR reg                                                                 |
| OR (III.)     | ZSP00                | 7         | B5               | $A \leftarrow A OR (HL)$                                                     |
| OR data8      | ZSP00                | 7         | F6 data8         | $A \longleftarrow A \text{ OR data8}$ $A \longleftarrow A \text{ OR (IY+d)}$ |
| OR (IY+d)     | ZSP00                | 19        | FD B6 dd         | $A \leftarrow A OR(IY+d)$                                                    |
| OR (IX+d)     | ZSPO 0               | 19        | DD B6 dd         | $A \leftarrow A OR(IX+d)$                                                    |
| OUT (no.),A   |                      | 11        | D3 no.8          | port (no.) ← A                                                               |
| OUT (C),reg   |                      | 12        | ED 01sss001      | port (C) ← reg                                                               |
| OUTI          |                      | 16        | ED A3            | $(HL) \longrightarrow port(C)$                                               |
|               |                      |           |                  | B-1>B                                                                        |
|               |                      |           |                  | $HL \longrightarrow HL+1$                                                    |
| OTIR          |                      | 16/21     | ED B3            | کرر OUTI إلى أن B=0                                                          |
| OUTD          |                      | 16        | ED A8            | $B \leftarrow B-1, port(C) \leftarrow (HL)$                                  |
|               |                      | "-        |                  | " III HL-i                                                                   |
| OTDR          |                      | 16/21     | ED B8            | کرر OUTD إلى أن B=0                                                          |
|               | or market and market | A, 11277. |                  | Harris of the self the control                                               |
| PUSH rp       |                      | 11        | 11rp0101         | المسجلان rp  قمة المكنسة                                                     |
| PUSH IY       |                      | 15        | FD E5            | المسجل IY> قمة المكدسة                                                       |
| PUSH IX       |                      | 15        | DD E5            | المسجل IX -> قمة المكدسة                                                     |
| POP rp        |                      | 11        | 11rp0001         | قمة المكدسة _ المسجلين rp                                                    |
| POPIY         |                      |           | FD E1            | قمة المكدسة ﴾ المسجل IX                                                      |
|               |                      |           |                  | قمة المكدسة — المسجل IX                                                      |
| POP IX        | and designates of    |           | DD E1            | TX Oxung — angel 43                                                          |
| RLCA          | CY -                 |           | 07               |                                                                              |
| I LLCA        |                      | '         |                  | CY← A ا                                                                      |
| I             | I                    | Ι .       | ı - I            |                                                                              |

| DIA        | CY -    | 4    | 17          |                                           |
|------------|---------|------|-------------|-------------------------------------------|
| RLA        | CI -    | 4    | 117         | ← CY ← A Jamel ←                          |
| RRCA       | CY -    | 4    | OF          | A lhamed CY                               |
| RRA        | CY -    | 4    | 1F          | ZA 0,501                                  |
| KKA        |         | -    | II.         | ∠A — lhaush — CY                          |
| RLC reg    | CY -    | 8    | CB 0000sss  | دوران مسجل , مثل RLCA                     |
| RLC (HL)   | CY -    | 15   | CB 06       | دوران عنوان في RLCAدوران عنوان            |
| RLC (IY+d) | CY -    | 23   | FD CB dd 06 | دور ان عنوان(IY+d)مثل RLCA                |
| RLC (IX+d) | CY -    | 23   | DD CB dd 06 | دور ان عنو ان(IX+d)مثل RLCA               |
| RL(HL)     | CY -    | 15   | CB 16       | دوران (HL) لليسار من خلال<br>علم الحمل    |
| RL (IX+d)  | CY -    | 23   | DD CB dd 16 | دور ان (IX+d) لليسار من خلال<br>علم الحمل |
| RL (IY+d)  | CY-     | 23   | FD CB dd 16 | دوران (IY+d) لليسار من خلال               |
| KL (111d)  | ļ       | 23   |             | علم الحمل                                 |
| RL reg     | CY -    | 8    | CB 00010sss | دور أن reg اليسار من خلال علم<br>الحمل    |
| RLD        |         | 18   | ED 6F       | دور ان 4بت الأولى من A للشمال             |
|            | i       |      | 1           | مع العنوان الموجود في HL                  |
| RRD        |         | 18   | ED 67       | دور ان 4بت الأولى من A لليمين             |
|            | <u></u> |      |             | مع العنوان الموجود في HL                  |
| RR (HL)    | CY -    | 15   | CB 1E       | دوران (.HI) لليمين من خلال علم<br>الحمل   |
| RR (IX+d)  | CY -    | 23   | DD CB dd 1E | دوران (IX+d) لليمين من خلال<br>علم الحمل  |
| RR (IY+d)  | CY -    | 23   | FD CB dd 1E | دوران (IY+d) لليمين من خلال<br>علم الحمل  |
| RR reg     | CY -    | 8    | CB 00011sss | دور ان reg اليمين من خلال علم<br>الحمل    |
| RRC (HL)   | CY -    | 15   | CB 0E       | دوران (HL) لليمين مثل RRCA                |
| RRC (IX+d) | CY -    | 23   | DD CB dd 0E | دور ان (IX+d) لليمين مثل RRCA             |
| RRC (IY+d) | CY -    | 23   | FD CB dd 0E | دور ان (IY+d) اليمين مثل RRCA             |
| RRC reg    | CY-     | 8    | CB 00001sss | دور ان reg اليمين مثل RRCA                |
| RET        |         | 10   | C9          | عودة من برنامج فرعى                       |
| RET Z      |         | 5/11 | C8          | عودة مشروطة بعلم الصفر-1                  |
| RET NZ     |         | 5/11 | CO          | عودة مشروطة بعلم الصفر -0                 |
| RET C      |         | 5/11 | D8          | عودة مشروطة بعلم الحمل- ا                 |
| RET NC     |         | 5/11 | D0          | عودة مشروطة بعلم الحمل-0                  |
| RET PO     |         | 5/11 | E0          | عودة مشروطة بعلم باريتي-0                 |
| RET PE     |         | 5/11 | E8          | عودة مشروطة بعلم باريتي- ا                |
| RET M      |         | 5/11 | F8 .        | عودة مشروطة بعلماشارة= ا                  |
| RET P      |         | 5/11 | F0          | عودة مشروطة بعلم إشارة=()                 |
|            | 4       |      |             |                                           |
| RETI       |         | 14   | ED 4D       | عودة من مقاطعة                            |

| RES b,reg     |            | 8   | CB 10bbbsss  | صفر في البت h في reg                                       |
|---------------|------------|-----|--------------|------------------------------------------------------------|
| RES b,(HL)    |            | 15  | CB 10bbb110  | صفر في البت b في (HL)                                      |
| RES b,(IX+d)  |            | 23  | DD CB dd     | صفر في البت h في (LX+d)                                    |
|               | 1          |     | 10bbb110     | (= , , , , , , , , , , , , , , , , , , ,                   |
| RES b,(IY+d)  |            | 23  | FD CB dd     | صفر في البت b في (١٧+d)                                    |
|               |            |     | 10bbb110     |                                                            |
| RST n         |            | 11  | llnnnlll     | إعادة تشغيل                                                |
|               |            |     |              |                                                            |
| SUB reg       | ZSPCYHC    | 4_  | 10010sss     | A ← A - reg                                                |
| SUB (HL)      | ZSPCYHC    | 7   | 96           | $A \leftarrow A - (HL)$                                    |
| SUB data8     | ZSPCYHC    | 7   | D6 data8     | A ← A - data8                                              |
| SUB (IX+d)    | ZSPCYHC    | 19  | DD 96 dd     | $A \leftarrow A - (IX+d)$                                  |
| SUB (IY+d)    | ZSPCYHC    | 19  | FD 96 dd     | $A \longleftarrow A \cdot (IY+d)$                          |
| SBC reg       | ZSPCYHC    | 4_  | 10011sss     | $A \leftarrow A - CY - reg$                                |
| SBC (HL)      | ZSPCYHC    | 7   | 9E           | $A \leftarrow A - CY - (HL)$                               |
| SBC data8     | ZSPCYHC    | 7   | DE data8     | A 		— A - CY - data8                                       |
| SBC (IX+d)    | ZSPCYHC    | 19  | DD 9E dd     | $A \leftarrow A - CY - (IX+d)$                             |
| SBC (IY+d)    | ZSPCYHC    | 19  | FD 9E dd     | $A \leftarrow A - CY - (IY+d)$                             |
| SBC HL,rp     | ZSPCYHC    | 15  | ED 01rp0010  | HL← HL-CY-rp                                               |
| SLA (HL)      | ZSPCYHC    | 2   | CB 26        | از احة (HL) لليسار ، حمل 0 في                              |
|               |            |     |              | بت 0                                                       |
| SI.A (IX+d)   | ZSPCYHC    | 4   | DD CB dd 26  | ازاحة (IX+d) لليمار ، حمل ()                               |
|               |            |     |              | ا في بث 0                                                  |
| SLA (IY+d)    | ZSPCYHC    | 4   | FD CB dd 26  | إزاحة (IY+d) لليسار ، حمل 0                                |
| , ,           |            |     |              | فی بث 0                                                    |
| SLA reg       | ZSPCYHC    | 2   | CB 00100sss  | إزاحة reg اليسارحمل 0 في بت0                               |
| SRL (HL)      | ZSPCYHC    | 2   | CB 3E        | از احة (IIL) لليمين ، حمل 0 في                             |
| (,            |            |     | 1            | بِتُ 7                                                     |
| SRL (IX+d)    | ZSPCYHC    | 4   | DD CB dd 3E  | ازاحة (HL) لليمين ، حمل () في                              |
| (2: -)        |            | _   |              | بت 7                                                       |
| SRL (IY+d)    | ZSPCYHC    | 4   | FD CB dd 3E  | از احة (HL) لليمين ، حمل 0 في                              |
| BIAL (11 · d) | ZBI CI IIC | , , | I D OD da se | بر — رسیر) کرین است تا |
| CDI           | ZSPCYHC    | 2   | CB 00111sss  | إزاحة reg لليمين ، حمل 0 في                                |
| SRL reg       | ZSPCINC    |     | CD 00111855  | بت 7                                                       |
| CD A (TT)     | ZSPCYHC    |     | CB 2E        | از احة (HL) لليمين ، بت 7 تظل                              |
| SRA (HL)      | ZSPCYHC    | 2   | CB 2E        |                                                            |
|               |            |     |              | كما هي                                                     |
| SRA (IX+d)    | ZSPCYHC    | 4   | DD CB dd 2E  | از احة (IX+d) لليمين ، بت 7                                |
|               |            |     |              | . تظل کما هی                                               |
| SRA (IY+d)    | ZSPCYHC    | 4   | FD CB dd 2E  | از احة (IY+d) لليمين ، بت 7                                |
| i             |            |     | ` T          | تظل کما هی<br>ازاحهٔ reg الیمین بیت7تظل                    |
| SRA reg       | ZSPCYHC    | 2   | CB 00101sss  |                                                            |
|               |            |     |              | كماهي                                                      |
| SET b,reg     | ZSPCYHC    | 8   | CB 11bbbsss  | کماهی<br>واحد فی البت b فی reg                             |
| SET b,(IY+d)  | ZSPCYHC    | 23  | I'D CB dd    | واحد فني البت b في (IY+d)                                  |
| ]             |            |     | 11666110     |                                                            |
| SET b,(HL)    | ZSPCYHC    | 15  | DD CB dd     | واحد في البت b في (HIL)                                    |
|               |            |     |              |                                                            |

| SET b,(IX+d) | ZSPCYHC | 23 | DD CB dd<br>11bbb110 | احد في البت b في (IX+d)     |  |  |
|--------------|---------|----|----------------------|-----------------------------|--|--|
|              |         |    |                      |                             |  |  |
| XOR reg      | ZSP00   | 4  | 10101sss             | A A XOR reg                 |  |  |
| XOR (HL)     | ZSP00   | 7  | AE                   | $A \leftarrow A XOR (HL)$   |  |  |
| XOR data8    | ZSP00   | 7  | EE data8             | A ←—A XOR data8             |  |  |
| XOR (IY+d)   | ZSP00   | 19 | FD AE dd             | $A \leftarrow A XOR (IY+d)$ |  |  |
| XOR (IX+d)   | ZSP00   | 19 | DD AE dd             | $A \leftarrow A XOR (IX+d)$ |  |  |

شكل (5–21) أوامر الشريحة 280 مرتبية أبجديا

- sss أو ddd تستبدل بشفرة مسجل 8 بت كما في فصل 2 .
  - rp تستبدل بشفرة زوج مسجلات كما في فصل 2 .
    - data8 ثابت مكون من 8 بت (بايت) .
    - dd إزاحة عنوانية مكونة من 8 بت (بايت) .
    - bbb رقم بت معينة في مسجل أو بايت ذاكرة .
- no.8 رقم (عنوان) بوابة (إدخال أو إخراج) من 8 بت (بايت) .

## **10−5** تـمــاريــن

1. أكمل الجدول التالى الخاص بأوامر الشريحة 280:



#### 2. ما هي نتيجة تنفيذ البرنامج التالي :

E000 LD A,05 E002 LD B,A E003 LD C,B E004 LD D,C E005 LD E,D E006 LD L,E E007 LD H,L E008 LD (HL),L

- اقرأ البرنامج السابق وأجب عما يلى :
- محتويات مكّان الذاكرة .....=E000

• مختويات مكان الذاكرة .....=E001

• محتويات مكان الذاكرة .....=0505

.4

E000 LD HL,E100

E003 LD (HL),3E

E005 INC HL

E006 LD (HL),05

E008 INC HL

E009 LD (HL),47

E00B INC HL

E00C LD (HL),48

ما هي نتيجة تتفيذ البرنامج السابق ؟

على ضوء نتيجة تنفيذ البرنامج السابق ما هي نتيجة تنفيذ الشفرات الموجودة في الأماكن E100 إلى E103 ؟

6. هل تتأثر الأعلام بأوامر الانتقال ؟

7. أذكر الأعلام التي تتأثر بكل عملية من العمليات الحسابية والمنطقية؟

8. إذا كانت محتويات المسجل A=F3H ومحتويات المسحل B=A4H فاكتنب محتويات المسجل A بعد تنفيذ كل أمر من الأوامر التالية على نفس المحتويات السابقة ووضح أيضا كيف سنتأثر الأعلام بكل أمر :

ADD A,B

SUB A,B

SUB A, A

INC A

AND B

OR B

XOR B

9. ارسم مخطط السير للبرنامج التالي وما هي نتيجة تتفيذه :

E000 LD L,50H

E003 LD H,E1H

E005 LD (HL),A

E006 DEC L

E007 JPNZ E005

10. ماذا يحدث لو كتبنا البرنامج السابق عند E100 بدلا من E000

11. أعد كتابة البرنامج السابق مستخدما العلامات Labels ؟ وما هـي مميزات البرنامج مكتوبا بهذه الصورة ؟

12. اكتب برنامجا يحسب عدد الوحايد الموجودة في محتويات المسجل A ، مثلا إذا كان A=11110101 فإن عدد الوحايد = A=1110101

- 13. كم عدد بوابات الإدخال التي يستطيع البروسيسور 280 التعامل معها؟
- 14. كم عدد بوابات الإخراج التي يستطيع البروسيسور 280 التعامل معها؟
  - 15. على ماذا يتوقف هذا العدد ؟
- 16. هل هناك ما يمنع أن تكون بوابتى إدخال وإخراج لهما نفس الرقم , كمثال على ذلك IN 05 و OUT 05?
- OUT (C), reg .17 هذا أحد أو امر الإخراج للبروسيسور Z80 والذي يعنى أخراج محتويات المسجل reg على بوابة الإخراج التي رقمها في المسجل C فيها البروسيسور 8085 لديه ما يكافىء هذا الأمر ؟
  - 18. هل تتأثر الأعلام بأوامر الإنخال والإخراج ؟
- 19. أكتب برنامجا يقرأ محتويات البوابة 00 وإذا كانت هذه المحتويات زوجية يخزنها في الذاكرة ابتداء من العنوان E100 وإذا كانت فردية يخرجها على البوابة 00 ؟
- 20. اذكر طرق العنونة memory addressings المستخدمة مع البروسيسور 280؟ والأوامر المستخدمة مع كل طريقة ؟ ومتى يفضل استخدام كل طريقة ؟
- 21. اكتب برنامج يحسب أكبر قيمة عددية في بايت في المدى العنوانـــي E200H الي المدى العنوانـــي E200H .
- 23. اكتب برنامج يحسب عدد البايتات التي تحتوى بيانات فردية والتي تحتوى بيانات زوجية في المدى العنواني E100 إلى E150 .
- 24. المدى العنواني E100 إلى E150 يحتوى بيانات الإشارة صوت ، احسب كـم مرة عبرت إشارة الصوت الصفر .
- 25. اكتب برنامج يقرأ بوابة الإدخال رقم 00 ويختبر البت الرابعة فيها ، فإذا كانت هذه البت واحد يخرج هذه المحتويات على البوابة 00 ، وإذا كانت هذه البت صفر يخرج محتوياتها على البوابة 01 .
- 26. اكتب برنامج يقرأ بوابة الإدخال رقم 00 إلى مالانهاية ويختبر البيانات التي يقرأها ، فإن كانت فردية يخرجها على البوابة 00 ، وإن كانت زوجية يخرجها على البوابة 01 ، احسب أكبر معدل لدخول البيانات لكى يعمل هذا النظام في الزمن المباشر real time .

# الفصل السادس

المعالج

من البداية ٠٠٠ حتى النهاية

Microprocessor... from Start ... to end

#### 6-1 مقدمة

سنقوم في هذا الفصل بعملية بناء تدريجية لمعالج افتراضي يقوم بعدد محدود من العمليات الحسابية والمنطقية وله عدد محدود من الأوامر كما أن له عددا محدودا جدا من الخطوط في مسارات البيانات والعناوين والتحكم ولذلك فإن هذا المعالج يستطيع التعامل مع كمية محدودة جدا من بايتات الذاكرة وسنبدأ عملية البناء من أقل مستوى ممكن ثم سنرتقي بها خطوة بخطوة إلى أن نصل إلى معالج متكامل ولكن بالمواصفات التي ذكرناها سابقا . من خلال عملية البناء سنتعرف على وحدة الحساب والمنطق وكيفية عملها . ولقد كان قصدنا من وضع هذا الفصل في هذا الترتيب أن يكون القارىء قد ألم بفكرة عامة عن تركيب المعالج من الفصول السابقة ثم يجيء هذا الفصل فيؤكد هذه الفكرة ويمحصها ويضيف إليها التفاصيل الدقيقة التي قد تجيب على الكثير من الأسئلة التي تدور في خلد أي قارىء عن كيفية تنفيذ أي معالج لأي أمر وما الذي يتحكم في عدد أوامره وغير ذلك من الأسئلة المهمة .

إن وحدة الحساب والمنطق هي إحدى المكونات الرئيسية للمعالج ومهمتها الأساسية هي إجراء العمليات الحسابية والمنطقية الأساسية وسنبدأ فيما يلي عملية بناء هذه الوحدة ولكي نصل إلى ذلك لابد أن نتعرف أو لا على كيفية تنفيذ عمليات الجمع والطرح في النظام الثنائي.

# 2-6 الجمع الثنائي Binary addition

## مثال 6-1

أوجد ناتج جمع الرقم A=a3a2a1a0 =1101 مع الرقم A=a3a2a1a0 =1011 الوجد ناتج عملية الجمع تتم كالتالى:

النتيجة S3 S2 S1 S0

كما نرى فإن عملية الجمع تتم على عدد من المراحل ، المرحلة الأولى هـى جمع a0 (البت الأولى من الرقم a0 فينتج مـن ذلك نتيجة a0 وحمل a1 إلى المرحلة التالية . في المرحلة الثانية يتم جمـع البتات الأتية :

c0 + b1 + a1

حيث co هي الحمل من المرحلة السابقة كما ذكرنا . نتيجة جمع المرحلة الثانيــة ستكون s1-0 والحمل منها سيكون c1-1 إلى المرحلة التالية . في المرحلة الثالثة ستتم عملية الجمع التالية :

c1 + b2 + a2

وسينتج عنها c2=1 و c2=1 و مرحلة الجمع الرابعة سيتم جمع البتات التالية: c2+b3+a3

وسينتج عنها 1=82 و 1=3 ويذلك تنتهى عملية الجمع ويتبقى حمل أخير للخانة الرابعة وهو 1=3 الذى سنهمله الآن ، من ذلك نرى أننا فى المرحلة الأولى an) المرابعة وهو 1=3 الذى سنهمله الآن ، من ذلك نرى أننا فى المرحلة الأولى عنهما المنت بت فقط 1=3 وأما فى باقى المراحل فإننا نجمع ثلاث بتات (an) 1=3 an فى البت رقم an فى العدد 1=3 an أيضا فى العدد 1=3 an أيضا فى العدد 1=3 an أيضا أيضا وما 1=3 an أيضا وما 1=3 an أيضا أيضا وما أيضا وما 1=3 an أيضا وما أيضا

## Half adder circuit, HA دائرة نصف المجمع 1-2-6

يقوم نصف المجمع المحمع 00 و وحمل 00 و وحمل 00 و وحمل 00 و وحمل المحمد الدائرة . من جدول المحمولة المحمد المحمد

| $s0 = a0 \overline{b0} + \overline{a0} b0$ | 1-6 |
|--------------------------------------------|-----|
| c0= a0b0                                   | 2-6 |

| ل ا | الدذ | _رج | الذ |
|-----|------|-----|-----|
| b0  | a0   | s0  | c0  |
| 0   | 0    | 0   | 0   |
| 0   | 1    | 1   | 0   |
| 1   | 0    | 1   | 0   |
| 1   | 1    | 0   | 1   |

شكل (6-1) جدول الحقيقة لنصف المجمع

من المعادلتين 6-1 و 6-2 نستطيع رسم دائرة منطقية لنصف المجمع كما في الشكل (6-2أ) . انظر أيضا في نفس الشكل إلى الرمز الذي سنستخدمه لهذه الدائرة .



### Full adder, FA دائرة المجمع الكامل 2-2-6

دائرة المجمع الكامل تكون قادرة على جمع ثلاثة بتات (cn-1, bn, an) وينتج منها المجموع sn والحمل للمرحلة القادمة cn . جدول الحقيقة لهذه الدائرة موضح فى شكل (3-6) . من جدول الحقيقة نستطيع كتابة معادلات الخرج كما يلى :

Sn=an 
$$\overline{bn}$$
  $\overline{cn-1}$  +  $\overline{an}$   $\overline{bn}$   $\overline{cn-1}$  +  $\overline{an}$   $\overline{bn}$   $\overline{cn-1}$  + an  $\overline{bn}$   $\overline{cn-1}$  +  $\overline{an}$   $\overline{bn}$   $\overline{an}$   $\overline{a$ 

Cn=an bn 
$$\overline{\text{cn-1}}$$
 + an  $\overline{\text{bn}}$  cn-1 +  $\overline{\text{an}}$  bn cn-1 + an bn cn-1 4-6

من المعادلتين 6-6 و 6-4 نستطيع استنتاج الدائرة المنطقية للمجمع الكامل كما في شكل (6-4) . من ذلك نرى أنه لجمع أى رقمين ثم سنحتاج مجمع لجمع البت رقم 0 في كل من الرقمين ثم سنحتاج مجمع لجمع البت رقم 0 في كل من الرقم الثانى مع الحمل الناتج من لجمع كل بت في الرقم الأول مع ما يناظرها في الرقم الثانى مع الحمل الناتج من عملية الجمع السابقة . فمثلا لو أن الرقمين A و B كل منهما يتكون من 4 بتات فإننا سنحتاج إلى نصف مجمع وثلاثة مجمعات كاملة لإتمام عملية جمع الرقميس ونفس الكلام يمكن تطبيقه على عملية جمع أى رقمين حيث كل منهما مكون من أى عدد من البتات . شكل (6-5) يبين الدائرة المستخدمة لجمع رقمين كل منهما مكون من أربعة بتات كمثال على ذلك . وترى في نفس الشكل الرمز العام المستخدم للمجمع .

| ــــــــــــــــــــــــــــــــــــــ | السدذ | رج | الذــــ |    |
|----------------------------------------|-------|----|---------|----|
| cn-1                                   | bn    | an | sn      | cn |
| 0                                      | 0     | 0  | 0       | 0  |
| 0                                      | 0     | 1  | 1       | 0  |
| 0                                      | 1     | 0  | 1       | 0  |
| 0                                      | 1     | 1  | 0       | 1  |
| 1                                      | 0     | 0  | 1       | 0  |
| 1                                      | 0     | 1  | 0       | 1  |
| 1                                      | 1     | 0  | 0       | 1  |
| 1                                      | 1     | 1  | 1       | 1  |

شكل (6-3) جدول الحقيقة للمجمع الكامل

# 3-6 الطرح الثنائى Binary subtraction

لإجراء عمليات الطرح الثنائى فإنه عادة ما نلجأ إلى تحويل عملية الطرح إلى عملية جمع وبعد نلك يمكن استخدام المجمع الذى سبق شرحه لتنفيذ عملية الطرح الى عملية جمع ننظر إلى المثال التالى:

#### مثال 6-2

one's الدينا الرقم 1101 = A فإن المعكوس أو المتمم الأحدادى one's الخرض أن لدينا الرقم = A = 0010 لهذا الرقم هو 0010 = A وتم ذلك عن طريق قلب كل 1 السلم وكل 0 إلى 1 في الرقم الأصلى . الآن ماذا يحدث أو جمعنا العدد الأصلى زائد واحد كما يلى = 0.

$$A = 1101$$
 ,  $A = 0010$   $A = 0000$   $A = 0000$ 

إن النتيجة كما رأينا ستكون دائما صفرا مع حمل واحد ، ولذلك فإنه بإهمال هـذا الحمل يمكننا كتابة العلاقة التالية :

$$A + \overline{A} + 1 = 0$$

ومنها يمكن كتابة الرقم A على الصورة التالية :

$$-A = A + 1$$
 5-6

وعلى ذلك فإنه من المعادلة (6–5) يمكننا أن نرى أن أى عملية طرح يمكس تحويلها إلى عملية جمع عن طريق استبدال المطروح بمتمسه الثنائي (المتمسم الأحادى + 1). كمثال على ذلك انظر إلى عمليات الطرح التالية وكيف حولناها إلى عمليات جمع:



$$A - B = A + \overline{B} + 1$$
 6-6  
 $B - C = B + \overline{C} + 1$  7-6

وبذلك نستطيع القول أنه يمكننا استخدام دائرة المجمع التي سبق شرحها في تنفيذ عمليات الطرح أيضا بعد إجراء بعض التعديلات الطفيفة عليها . شكل (6-6) يبين دائرة مجمع وقد تم عليها هذا التعديل لتقوم بعمليات الجمع أو الطرح عسن

طريق بعض خطوط التحكم التى يمكن بواسطتها اختيار إما عملية الجمع أو عملية الطرح .



كما نعلم فإنه من خواص بوابة XOR أن لها دخلان عندما يكون أحدهما يسلوى واحدا فإن الخرج يكون معكوس الدخل الآخر ، وعندما يكون أحد هذين الدخلين يساوى صفرا فإن الخرج يكون مثل الدخل الآخر ، أى أن بوابة XOR يمكن استخدام أحد دخليها للتحكم في جعل الخرج يساوى أما الدخل الآخر أو معكوسه. يمكن أن نرى ذلك بوضوح في شكل (6-6) بحيث أنه إذا كان خط التحكم 1=1 فإن العدد 1=1 سيدخل للمجمع معكوس ، أما إذا كان 1=1 فإن العدد 1=1 سيدخل المجمع بقيمته الحقيقية ، نفس الشيء تم تطبيقه على العدد 1=1 باستخدام خط التحكم 1=1

من شكل (6-6) أيضا يمكننا استنتاج وظيفة خطى التحكم S4, S3 بأن كل منهما بمثابة مفتاح (ON/OFF) للعدد الذي يعمل معه . فالخط S3 سيسمح بمرور العدد B أو صفر بدلا منه ، والخط S4 سيسمح بمرور العدد A أو صفر بدلا منه ، إنه باستخدام خطوط التحكم S4, S3, S2, S1 يمكن استخدام المجمع الموجود في شكل (6-6) في أكثر من وظيفة منها الجمع والطرح . إفترض مثلا أن S=1

يساوى S1=0, S0=0, S3=1, S2=0, S1=0, S0=0, S3=1, S2=0, S1=0, S0=0, S3=1, S2=0, S1=0, S1=0 العددين S1=0, S1=0 العددين S1=0, S1=0 العددين S1=0, S1=0 المجمع سيكون دخلاء المباشران S2=0, S1=0 المجمع سيكون دخلاء المباشران S1=0, S1=0 وصفر من خط التحكم S1=0 المجمع سيكون بجمعها .



افترض الآن الوضع التالى S4=1, S3=1, S2=0, S1=1, S0=1 من شكل S4=1, S3=1, S3=1, S3=1, S3=1, S4=1, S5=1, S5=1

 $A + \overline{B} + 1$ 

حيث الواحد هو قيمة خط التحكم SO . كما علمنا من قبل فإن B=B-1 لذلك فإننا نستطيع القول بأن المجمع في هذه الحالة يقوم بعملية طرح العدد B من العدد A ، أي (A-B) .

شكل (6-6) به خمسة خطوط تحكم هي  $(2^5)$  شفرة أو كود يمكن أن تكون عليها يكون و احدا أو صفرا لذلك فإن هناك  $(2^5)$  شفرة أو كود يمكن أن تكون عليها هذه الخطوط و لكل شفرة من هذه الشفرات سيكون هناك خسرج معين لدائسرة المجمع/الطارح الموضحة في شكل (6-6) . شكل (6-7) يبين جميع هذه الشفرات و الخرج الناتج عن كل منها . إننا هنا لن نقوم بمراجعة جميع الحالات الموجودة في شكل (6-7) لمعرفة كيف يكون الخرج في كل حالة و مطابقة ذلك على الدائرة الموجودة في شكل (6-6) و لكننا سنترك هذه العملية للقارىء اكتفاء بالمثالين اللذين شرحناهما سابقا أحدهما للجمع و الآخر للطرح . من الملاحظات المهمة على الخرج أن هناك الكثير من الحالات قد يكون فيها الخرج غير مسهم مثل الحالات التي يكون فيها الخرج يساوى (1-1) و الحالات التي يكون الخرج فيها مكررا مثل الحالات التي يكون الخرج فيها الخرج يساوى (1-1) و الحالة التي يكون فيها الخرج يساوى (1-1) و الحالة التي يكون فيها الخرج يساوى (1-1) و الحالة التي يكون فيها الخرج يساوى (1-1) و الحالة التي الذكرار و هذه الحالات التي نعتبرها غير مهمة (1-1) و هذه الحالات التي نعتبرها غير مهمة (1-1) و هذه المناه في الأجزاء القادمة .

## 4-6 وحدة الحساب والمنطق Arithmatic and Logic Unit, ALU

من العمليات التى يقوم بها المعالج دائما بجانب العمليسات الحسابية العمليسات المنطقية أيضا . لذلك فإننا سنحاول في هذا الجزء و عن طريق إضافية بعض خطوط التحكم أن نجعل الدائرة الموجودة في شكل (6-6) قسادرة على تنفيذ العمليات المنطقية أيضا بجانب العمليات الحسابية (الجمع والطرح) . إن العمليات المنطقية التي سنحاول إضافتها إلى وحدة المجمع/الطارح التي سبق شرحها هي عمليات XOR, OR, AND وهذا كمثال فقط حيث بالطبع يمكن إضافة المزيد . عمليات أكثر من طريقة لتطوير دائرة المجمع/الطارح التي سبق شرحها لتستطيع تنفيذ العمليات المنطقية وسنعرض هنا أبسط هذه الطرق . شكل (6-8) يبين وحدة حساب ومنطق تستطيع تنفيذ عمليات الجمع والطرح و QO و XOR و كل منهما مكون من  $\alpha$  من البتات ولكن لتبسيط الرسم تم رسمه كخط واحد فقط . شكل (6-8) مكون من  $\alpha$  الصندوق ولكن لتبسيط الرسم تم رسمه كخط واحد فقط . شكل (6-8) مكون من البعدة

الأول خاص بعمليتي الجمع والطرح ومحتوياته هي الدائرة الموجودة في شــكل (6-6) .

| s4 | <b>s</b> 3 | s2 | <b>s</b> 1 | s0 | الخسرج  |
|----|------------|----|------------|----|---------|
|    |            |    |            |    |         |
| 0  | 0          | 0  | 0          | 0  | 0       |
| 0  |            |    | 1          |    | 1       |
| 0  | 0          | 0  | 1          | 0  | -1<br>0 |
| 0  | 0          | 1  | 0          | 0  | -1      |
| 0  | 0          | 1  | 0          | l  | 0       |
| 0  | 0          | 1  | 1          | 0  | -2      |
| 0  | 0          | 1  | 1          | 1  | -1      |
| 0  | 1          | 0  | 0          | 0  | В       |
| 0  | 1          | 0  | 0          | ı  | B+1     |
| 0  | 1          | 0  | 1          | 0  | -B-1=B  |
| 0  | 1          | 0  | 1          | 1  | -B      |
| 0  | 1          | 1  | 0          | 0  | B-1     |
| 0  | 1          | 1  | 0          | 1  | В       |
| 0  | 1          | 1  | 1          | 0  | -B-2    |
| 0  | 1          | 1  | i          | i  | -B-1=B  |
| 1  | 0          | 0  | 0          | 0  | A       |
| 1  | 0          | 0  | 0          | l  | A+1     |
| 1  | 0          | 0  | 1          | 0  | A-1     |
| 1  | 0          | 0  | 1          | 1  | A       |
| 1  | 0          | 1  | 0          | 0  | -A-1=A  |
| 1  | 0          | 1  | 0          | l  | -A      |
| 1  | . 0        | I  | 1          | 0  | -A-2    |
| 1  | 0          | 1  | 1          | 1  | -A-1=A  |
| 1  | 1          | 0  | 0          | () | A+B     |
| 1  | 1          | 0  | 0          | l  | A+B+1   |
|    | l          | 0  | 1          | () | A-B-1   |
| 1  | 1          | 0  | 1          | 1  | A-B     |
| l  | 1          | 1  | ()         | 0  | B-A-I   |
| 1  | 1          | 1  | U          | 1  | B-A     |
| 1  | 1          | 1  | 1          | () | -A-B-2  |
| 1  | 1          | 1  | 1          | 1  | -A-B-1  |

شكل (6-6) جميع الحالات الممكنة لخرج المجمع/الطارح في شكل (6-6)

الصندوق الثانى خاص بعملية AND ويحتوى عددا n من بوابات AND ثنائيسة الدخل حيث أحد هذين الدخلين هو بت من بتات الدخل A والدخل الآخر هسو البت المناظرة من الدخل B . الصندوق الثالث خاص بعملية OR ومحتوياته هى عدد n من بوابات OR ثنائية المدخل n وأما الصندوق الرابع فخاص بعمليسة XOR ومحتوياته هى عدد n من بوابات n

الخرج النهائي لوحدة الحساب والمنطق يتم اختياره من بين خروج الأربعة صناديق السابقة عن طريق منتخب multiplexer له خطى تحكم 86,85 تتم بهما عملية اختيار أي واحد من الصناديق سيتم توصيل خرجه إلى خرج المنتخب وبالتالي إلى خرج وحدة الحساب والمنطق ، فمثلا إذا كان 6=55 فيان وحدة لحساب والمنطق ستقوم بتنفيذ عملية XOR على الدخلين B, A . شكل (6-8) الحساب والمنطق ستقوم بتنفيذ عملية XOR على الدخلين B, A . شكل (6-8) بيين أيضا جدول الحقيقة لهذا المنتخب لجميع حالات الخطين 86,85 . لاحظ أن عملية تخصيص أي شفرة على الخطين 86,85 ستخرج ROD وأيها ستخرج أن عملية تخصيص أي شفرة على الخطين 68,85 ستخرج 86,0 كالمصملة إذ هو الذي يحدد هذه الشفرات . عندما يكون الخطان 0=55,0 =65 فإن خسرج وحدة الحساب والمنطق سيكون هو خرج الصندوق المجمع/الطارح وأما العملية التي سنتفذ فستكون إما عملية جمع أو طرح أو غير ذلك على حسب الشفرة الموجودة على باقي خطوط التحكم 80 إلى 84 .

الدائرة الموجودة في شكل (6-8) تحتوى على سبعة خطوط تحكم S0 إلى وعلى ذلك فإن هذه الدائرة مفروض أن تكون قادرة على إجراء 128 (7) عملية مختلفة بناء على جدول حقيقة يمكن وضعه مماثلا للجدول المبين في شكل (6-6) . ولكن وكما رأينا في شكل (6-7) فإن معظم هذه العمليات (128) إما أنها ستكون عمليات غير مهمة أي غير ذات فائدة أو أنها ستكون عمليات مكررة . لذلك فإننا سنقوم بتصفية هذه 128 عملية إلى 13 عملية فقط من العمليات المهمة والغير مكررة وسنهمل باقى العمليات . لاحظ أن اختيار 13 عملية تعتبر من عمل المصمم حيث هو الذي يختار عدد العمليات المهمة وأي العمليات تسهمل؟ وأيها يؤخذ في الإعتبار؟ ولذلك فإن اختيارنا 13 عملية هنا ليس إلا مجرد مثال فقط ولا توجد أي ضرورة لاختيار الرقم 13 بالذات .

بما أننا سنختار 13 عملية فقط وسنهمل الباقى فإنه من البديهى أن يكون هنساك 4 خطوط تحكم فقط كافية لتشفير هذه العمليات حيث  $^4$  =10 (أكبر من 13). لذلك فإننا سنحتاج هنا إلى دائرة تكون مهمتها هى تحويل الشفرات الرباعية إلى شفرات سباعية تتناسب مع خطوط التحكم الموجودة في وحدة الحساب والمنطق المبينة في شكل ( $^6$ -8) ، هذه الدائرة سنسميها محول شفرات وعادة ما تكون هذه الدائرة عبارة عن ROM مكونة من 16 بايت ولها أربعة خطوط عناوين تعطيى

عليها الشفرة الرباعية فتخرج محتويات البايت المقابلة وهي الشفرة السباعية التي من المفروض أن تكون مخزنة سلفا .



شكل (6-9) يبين رسما صندوقيا وجدول الحقيقة لمحول الشفرات . شكل (6-10) يبين الشكل النهائي لوحدة الحساب والمنطق بعد إضافة محول الشفرات إليها . لإجراء عملية الجمع مثلا يجب أن نضع الشفرة الرباعية 111 0 علي خطوط التحكم 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110 110

# مسجل التراكم 5-6 Accumulator register

إن إضافة مسجل التراكم Accumulator إلى وحدة الحساب والمنطق هو الخطوة التالية لتطوير هذه الوحدة وإعدادها لتكون جزءا من أجزاء المعالج. شكل (6-11) يوضح هذا التطوير ، من هذا الشكل نلاحظ أن مسجل التراكم يعتبر مخزنا لتسجيل الناتج من وحدة الحساب والمنطق حيث أنه موصل مباشرة على خرجها ولذلك فإننا نتوقع أن ناتج أي عملية حسابية أو منطقية سيذهب مباشرة إلى مسجل

التراكم . نلاحظ أيضا من شكل (11-6) أن هناك نوعا من أنواع التغذية المرتدة حيث قد تم توصيل خرج مسجل التراكم على أحد دخلى وحدة الحساب والمنطق (الدخل A) ولم يبق سوى دخل واحد فقط لوحدة الحساب والمنطق (الدخلل B) . نلاحظ أيضا أن مسجل التراكم مثله مثل أى مسجل حيث لن ينتقل دخله السي خرجه إلا بعد إعطاء نبضة ترامن clock ، لذلك كان لابد من توصيل clock المسجل التراكم .



شكل (6-9 أ) رسم صندوقي لمحول الشفرات

|     | U  | U  | Ü | العملية     | s6                    | s5        | s4     | <b>s3</b> | s2   | s1   | s0   |
|-----|----|----|---|-------------|-----------------------|-----------|--------|-----------|------|------|------|
| 3   | 2  | 1  | 0 |             |                       |           |        |           |      |      |      |
| 0   | 0  | 0  | 0 | A           | 0                     | 0         | 1      | 0         | 0    | 0    | 0    |
| 0   | 0  | 0  | 1 | 1           | 0                     | 0         | 0      | 0         | 0    | 0    | 1    |
| 0   | 0  | 1  | 0 | A           | 0                     | 0         | 1      | 0         | 1    | 0    | 0    |
| 0   | 0  | 1  | 1 | В           | 0                     | 0         | 0      | 1         | 0    | 0    | 0    |
| 0   | 1  | 0  | 0 | 0           | 0                     | 0         | 0      | 0         | . 0  | 0    | 0    |
| 0   | 1  | 0  | 1 | A+1         | 0                     | 0         | 1      | 0         | 0    | 0    | 1    |
| 0   | 1  | 1  | 0 | <b>A-</b> 1 | 0                     | 0         | 1      | 0         | 0    | 1    | 0    |
| 0   | 1  | 1  | 1 | A+B         | 0                     | 0         | 1      | 1         | 0    | 0    | 0    |
| 1   | 0  | 0  | 0 | A-B         | 0                     | 0         | 1      | 1         | 0    | 1    | 1    |
| 1   | 0  | 0  | 1 | A∧B         | 1                     | 0         | d      | d         | d    | d    | d    |
| 1   | 0  | 1  | 0 | A∀B         | 0                     | 1         | d      | d         | d    | d    | d    |
| 1   | 0  | 1  | 1 | A+B         | 1                     | 1         | d      | d         | d    | d    | d    |
| 1   | 1  | 0  | 0 | -1          | 0                     | 0         | 0      | 0         | 1    | 1    | 1    |
| 1   | 1  | 0  | 1 | ث           | ت الثلا               | الحالا    | هذه    |           |      |      |      |
| 1   | 1  | 1  | 0 | ڏن          | فدمة ال               | مست       | غير    |           |      |      |      |
| 1   | 1  | 1  | 1 | تقبلا       | وسوف نستخدمها مستقبلا |           |        |           |      |      |      |
| 1 , | نة | لم |   | ن هذا الخ   | أن بكو                | ۔۔۔لا یہم | d أي ا | not       | care | تعنى | d *  |
| ľ   |    |    |   |             |                       | 1         |        |           |      |      | واحد |

شكل (6-9ب) جدول الحقيقة لمحول الشفرات



بعد هذا التعديل بإضافة مسجل التراكم إلى وحدة الحساب والمنطق لابد وأن يطرأ تعديل مناظر على ال 13 عملية التي تم تخصيصها لهذه الوحدة للقيام بها والتي سبق أن حددناها سابقا بعد إضافة محول الشفرات في شكل (6-9) . شكل (12-6) يبين جدو لا لهذه العمليات وقد تم إعطاء شفرة حرفية mnomenic أو شفرة أسمبلي لكل عملية بجانب شفرتها الثنائية (الشفرة الرباعية) أو التي سنسميها شفرات الماكينة machine codes . لنأخذ على ذلك المثال التالي : افترض أن خطوط التحكم U3 U2 U1 U0 تساوى 0101 فإنه من شكل (6-9) ستكون العملية (الأمر) التي ستنفذ هي 1+A ، أي أن الدخل A لوحدة الحساب والمنطق الذي هو خرج مسجل التراكم سيزداد بمقدار واحد . بافتراض أن خرج مسجل التراكم كان صفرا في البداية فإن ال ALU ستجمع واحد زائد صفر وتكون النتيجة واحدا يوضع على خرج ال ALU . مع أول نبضة تزامن فإن هذا الواحد ينتقل إلى خرج مسجل التراكم حيث سيكون موجودا أيضا على الدخل A لل ALU . ومع بقاء نفس الشفرة على الخطوط U0 إلى U3 فإن هـذا الواحـد سيصبح اثنين على خرج ال ALU . بإعطاء نبضة التزامن الثانية ستتنقل الاثنين إلى خرج مسجل التراكم والدخل A لل ALU وهكذا تستمر العملية . أي أن هــذا الأمر يزيد واحدا على محتويات مسجل التراكم مع كل نبضة تزامن كما لو كلن عدادا ولذلك فقد تم اختصاره إلى INC أى زد بمقدار واحد Increment .



كما نلاحظ من شكل (6-11) فإن خرج مسجل التراكم متصل دائما بــالدخل A لوحدة الحساب والمنطق لذلك فإنه دائما يطلق عليه إسم المسجل A ، وبمــا أن النتائج دائما نتراكم فيه كما رأينا في المثال السابق فقد أطلق عليه أيضها اسم مسجل التراكم أو المركم Accumulator . لنأخذ مثالا آخر أكثر تعقيدا لكي نفسهم كيفية عمل الدائرة الموجودة في شكل (6-11) . افترض أن المطلوب هو ضرب العددين 3×6 . كما نرى من شكل (6-12) فإنه ليس هناك أي أمر يقوم بعمليـــة الضرب ، لذلك فإننا سننفذ الضرب عن طريق الجمع المتكرر ، أي أننا سنجمع العدد 6 مع نفسه ثلاث مرات . لذلك فإننا سنضع العدد 6 على الدخل B أو لا ثم سنضع الشفرة 0011 على خطوط التحكم U0 إلى U3 وهذه الشفرة من شانها أن تنقل الموجود على الدخل B إلى خرج مسجل التراكم مع أول نبضة ترامن ، أي أنه بعد أول نبضة تزامن سيكون العدد 6 موجودا على خرج مسحل التراكم وبالتالي أيضا على الدخل الآخر (الدخل A) لوحدة الحساب والمنطق . الأن سنضع الشفرة 0111 على خطوط التحكم U0 إلى U3 وهذه الشفرة كما في شكل (12−6) ستقوم بجمع محتويات الدخل B مع محتويات الدخــــل A لـــل ALU . وعلى ذلك فإنه بإعطاء نبضة تزامن ثانية ستكون محتويات مسجل التراكم تساوى 12 وهي حاصل جمع 6 الموجودة على الدخل B و 6 الموجـــودة علــي خرج مسجل التراكم بعد النبضة الأولى . لاحظ أن الدخــل A لـل ALU بعـد النبضة الثانية سيصبح 12 أيضا . لو احتفظنا بنفس الشفرة 0111 على خطوط التحكم U0 إلى U3 وأعطينا نبضة ترامن أخرى فان خرج مسجل التراكم سيصبح 18 وهي حاصل جمع 6 الموجودة على الدخل B و 12 الموجودة على علي خرج مسجل التراكم بعد النبضة الثانية . بذلك نكون قد أنهينا عملية ضرب العددين 3×6 بعد ثلاث نبضات ترامن وبعد أن وضعنا الشفرات التالية على خطوط التحكم U0 إلى U3 :

U3 U2 U1 U0 أول نبضة تزامن 0 0 1 1 1 0 0 ثانى نبضة تزامن 0 1 1 1 1 0 ثالث نبضة تزامن 0 1 1 1 0 0 ثالث نبضة تزامن

من المثال السابق يمكننا أن نقول أن أى عملية مركبة يمكن تبسيطها إلى مجموعة من الشفرات التى توضع على خطوط التحكم UD إلى U3 واحدة بعد الأخرى بحيث تنفذ العملية المناظرة لكل شفرة مع نبضة تزامن . الأن ألا يمكننا أن نسمى كل شفرة من هذه الشفرات بالأمر Instruction ، ومجموعة الشفرات أو الأوامر المطلوبة لتنفيذ أى عملية مركبة ألا نسميها برنامج program ، ألا يمكن أن نسمى الدائرة التى لها قائمة الأوامر الموجودة فسى شكل (6-12) بعتبر صورة بالمعالج . نعم إن الدائرة التى حصلنا عليها فى شكل (6-11) تعتبر صورة مبسطة جدا لمعالج افتراضى محدود الإمكانيات إذا ما قورن بأى معالج حقيقى . إن المعالج الإفتراضى المعالج الشوال الذى وصلنا إليه حتى الأن يستطيع فقط إجراء العمليات الحسابية والمنطقية ، السؤال الآن هل نستطيع تطوير الوحدة السابقة لكى تستطيع التعامل مع ذاكرة ووحدات إدخال أو إخراج كما فى المعالج العادى ؟ إن هذا ما سنراه فى الجزء التالى :

## 6-6 إضافة ذاكرة للمعالج الإفتراضي

بالنظر إلى الدائرة الموجودة في شكل (6—13) نجد أن هناك منتخبا تمت إضافته في الدخل وهذا المنتخب له دخلان وخط تحكم واحد 88 تمث إضافته على خرج محول الشفرات لهذا الغرض . أحد دخلى هذا المنتخب هـــو خــرج الذاكـرة والدخل الآخر هو الدخل 8 حيث يتم اختيار أحدهما ليعبر إلى خرج المنتخــب ومنه كدخل إلى وحدة الحساب والمنطق ثم إلى مسجل التراكم عن طريق خــط التحكم 88. وعلى ذلك فعندما يكون 9=88 فإن خرج الذاكرة يكون موصلا إلى وحدة الحساب والمنطق ، وأما إذا كان 1=82 فإن الدخل 1 يوصل إلـــى وحـدة الحساب والمنطق .

| U3   | U2 | U1 | U0   | اختصار       | العمليسة                       | الحمل      |
|------|----|----|------|--------------|--------------------------------|------------|
|      |    |    |      | العملية      |                                | Carry      |
| 0    | 0  | 0  | 0    | NOP          | لاتعمل شيء                     | no         |
| 0    | 0  | 0  | 1    | SP1          | $\mathbf{A} = +1$              | no         |
| 0    | 0  | 1  | 0    | CMA          | اعكس ٨                         | no         |
| 0    | 0  | 1  | 1    | LDA          | حمل A بالدخل B                 | no         |
| 0    | 1  | 0  | 0    | CLA          | A = 0                          | no         |
| 0    | 1  | 0  | 1    | INC          | $A+1 \longrightarrow A$        | yes        |
| 0    | 1  | 1  | 0    | DEC          | $A-1 \longrightarrow A$        | yes        |
| 0    | 1  | 1  | 1    | ADD          | $A+B \longrightarrow A$        | yes        |
| 1    | 0  | 0  | 0    | SUB          | $A-B \longrightarrow B$        | yes        |
| 1    | 0  | 0  | 1    | AND          | $A \land B \longrightarrow A$  | no         |
| 1    | 0  | 1  | 0    | OR           | $AVB \longrightarrow A$        | no         |
| 1    | 0  | 1  | 1    | XOR          | $A \oplus B \longrightarrow A$ | no         |
| 1    | 1  | 0  | 0    | SM1          | -1 <del>-&gt;</del> A          | no         |
| 1    | 1  | 0  | 1    |              |                                |            |
| 1    | 1  | 1  | 0    |              |                                |            |
| 1    | 1  | 1  | 1    |              |                                |            |
| وحدة | B  | ل  | الدخ | B يقصد بها ا | د بها مسجل التراكم و           | * A مقصو   |
|      |    |    |      |              | منطق                           | الحساب وال |

شكل (6-12) قائمة بالعمليات التي تنفذها وحدة الحساب والمنطق التي معها مركم كما في شكل (6-11)

المشكلة الآن أننا نريد توصيل أحد هذين الدخلين إلى مسجل الستراكم فأى الشفرات نضعها على خطوط التحكم U0 إلى U3 إلى هناك الا شفرة واحدة فقط وهى الشفرة 1001 التى تضع دخل وحدة الحساب والمنطق فسى مسجل التراكم وهى شفرة الأمر LDA وكما رأينا فإن دخل وحدة الحساب والمنطق إما أن يكون من الذاكرة أو من B. لذلك فإنه لتمبيز كل من الدخلين من الآخر فإننا سنخصص الشفرة 1001 التى هى الأمر LDA لتحميل المركم بمحتويات دخسل وحدة الحساب والمنطق إذا كان هذا الدخل قادما من الذاكرة أى 0=88. ولذلك فإنه فى هذه الحالة (0=88) لابد من تحديد العنوان الذى سيتم التعامل معه على خطوط عنوان الذاكرة 0ه إلى 23. أما إذا كان الدخل قادما من B فإننا سنستخدم خطوط عنوان الذاكرة 10 إلى 23. أما إذا كان الدخل قادما من المفرة الموجودة فى قائمة الأوامر ولتكن الشفرة 101 والتى سنعطيها الاختصار 1NP أى الدخل من

خارج المعالج مثل بوابة إدخال مثلا . لاحظ أنه مع الأمر INP فإن خط التحكم S8 يكون واحدا في هذه الحالة وستكون الشفرة المقابلة على خرج محول الشفرات S0 إلى S8 هي 00001000 .



بذلك نكون قد رأينا كيفية اختيار دخل وحدة الحساب والمنطق بين الذاكرة أو الدخل B القادم من خارج المعالج ، ماذا عن خرج وحدة الحساب والمنطق وكيف يمكن توصيله إلى الذاكرة ؟

إن خط التحكم S7 الذي أضيف على خرج محول الشفرات كما في شكل (6-S7) مهمته هي التحكم في كتابة خرج مسجل التراكم في الذاكرة إذا كسان S71 أو إخراجه إلى خارج المعالج عندما يكون S72. لاحظ أن كلا من هاتين العمليتين ليس لها أمر يقابلها في قائمة الأوامر التي درسناها حتى الآن في شكل (S72) ولذلك فإننا سنستخدم الشفرتين المتبقيتين من ال S74 شخرة في نفسس الشكل لهذا الغرض . أي أن الشفرة S74 والتي سنختصرها S75 أي خزن في الذاكرة S75 الغرص . أي أن الشفرة S76 الذي سيجعل الذاكرة في حالسة الذاكرة من المعلومات أي في حالة كتابة فيها لأن الخط S76 الذي سيتط أن هذا الأمر سيتطلب أن نضع العنوان الذي سيتم التعامل معه داخل الذاكرة على مسار العناوين (S76 ألى دو المناوين (S78 ألى دو المناوين (S78 ألى دو المناوين (S78 ألى الغناوين (S78 ألى دو المناوين (S78 ألى المناوين (S78 ألى دو المناوية المناوية المناوية (S78 ألى دو المناوية (S78 ألى دو المناوية (S78 ألى دو المناوية (S79 ألى دو المناوية (ألى دو المن

| U: | 3 U2 | U1 | U0 | ران | )    | نـــــ | J) | الأمر | العمليــة                    | الحمل |
|----|------|----|----|-----|------|--------|----|-------|------------------------------|-------|
|    |      |    |    | a.  | 3 a2 | a1     | a0 |       |                              |       |
| 0  | 0    | 0  | 0  | Х   | х    | X      | х  | NOP   | لاتعمل شيء                   | no    |
| 0  | 0    | 0  | 1  | X   | Х    | х      | Х  | SP1   | A = +1                       | no    |
| 0  | 0,   | 1  | 0  | Х   | Х    | Х      | X  | CMA   | اعکس A                       | no    |
| 0  | 0    | 1  | l  | a   | a    | a      | a  | LDA   | الذاكرة 🔫                    | no    |
| 0  | 1    | 0  | 0  | Х   | Х    | х      | Х  | CLA   | A = 0                        | no    |
| 0  | I    | 0  | 1  | Х   | Х    | Х      | х  | INC   | $A+1 \longrightarrow A$      | yes   |
| 0  | 1    | 1  | 0  | X   | Х    | х      | х  | DEC   | $A-1 \longrightarrow A$      | yes   |
| 0  | 1    | 1  | 1  | a   | a    | a      | a  | ADD   | عنو ان+A→A                   | yes   |
| 1  | 0    | 0  | 0  | a   | a    | a      | a  | SUB   | عنوان- A <del>─</del> A      | yes   |
| I  | 0    | 0  | 1  | a   | a    | a      | a  | AND   | عنو ان\A —>A                 | no    |
| 1  | 0    | 1  | 0  | a   | a    | a      | a  | OR    | عنو ان\A ← A                 | no    |
| I  | 0    | 1  | 1  | a   | a    | a      | a  | XOR   | عنو ان⊕۸ → A                 | no    |
| 1  | 1    | 0  | 0  | х   | х    | х      | х  | SM1   | -1 <del>&gt;</del> A         | no    |
| 1  | 1    | 0  | 1  | Х   | X    | х      | Х  | INP   | $B \longrightarrow A$        | no    |
| 1  | 1    | 1  | 0  | a   | a    | a      | a  | STA   | $A \longrightarrow $ الذاكرة | no    |
| 1  | 1    | 1  | 1  |     |      |        |    | OUT   | A—≫الخر ج                    | no    |

شكل (6-14) قائمة الأوامر بعد تعديلها لتلائم عملية الإتصال بالذاكرة

أما الشفرة 1111 المتبقية فسوف نخصصها لإخراج محتويات المركم خارج المعالج ولذلك سنرمز لها بالرمز OUT أى إخراج output حيث سيكون الخط S7=0 في هذه الحالة . شكل (6-14) يبين قائمة الأوامر بعد تعديلها لتناسب عملية التوصيل للذاكرة وإضافة الأوامر الجديدة إليها .

إننا بعد دراسة هذا الفصل يجب أن نقف وقفة تفكير في الفرق بين هذا المعالج الإفتراضي وأي واحد من المعالج الحقيقي الذي درسناه في الفصدول السابقة . أسئلة كثيرة يمكن أن ترد هنا بعد دراسة الأشكال المختلفة والمتعددة التي رأيناها في هذا الفصل . كيف سيكون شكل المعالج لو أننا رسمناه على أساس 8 بتات أو 16 أو حتى 32 بت ؟ وماذا لو جعلنا الشفرة الداخلة إلى محول الشفرات شفرة من 16 بت بدلا من الشفرة الرباعية ؟ وكيف سيكون شكل هذه الدائرة إذا أضفنا بعض العمليات الأخرى مثل عمليات دوران محتويات المسجل A إلى اليمين أو اليسار وعمليات الضرب والقسمة ؟ كيف سيكون شكل هذه الدائرة لو أضفنا لهذه الوحدة بعض المسجلات عامة كيف سيكون شكل هذه الدائرة لو أضفنا لهذه الوحدة بعض المسجلات عامة الأغراض التي تستخدم لأغراض التخزين وتبادل المعلومات مع المسجل A ؟

كيف سيكون شكل الدائرة لو أن الوحدة تتعامل مع ذاكرة لها 16 أو 32 خطا من خطوط العناوين بدلا من 4 كما افترضنا ؟ كل هذه أسئلة توضح مدى بساطة فكرة عمل المعالج ولكنها في نفس الوقت توضح مدى تعقيد تركيبه ومكوناته .

#### 7-6 تـمـاريـن

- 1. دائرة نصف المجمع الموجودة في شكل (2-6) يمكن بناؤها باستخدام بو ابسات XOR ، وضح ذلك ?
- 2. دائرة المجمع الكامل الموجودة في شكل (6-4) يمكن بناؤها باستخدام نصفى مجمع ، وضع ذلك ؟
- 3. هناك بعض الشرائح التى تعمل كمجمع ، اذكر واحدة مسن هده الشرائح واشرح طريقة عملها واختبرها معمليا؟ استعن بكتاب data book دليل الشرائح.
- لعب المتمم الثنائي دورا مهما في تحويل عملية الطرح إلى عملية جمع ،
   وضح ذلك بالشرح ؟
  - 5. ما هو دور وحدة الحساب والمنطق في المعالج ؟
- هناك بعض الشرائح التى تعمل كوحدة حساب ومنطق ، اذكر و احدة من هذه الشرائح ، و اشرح طريقة عملها و اختبرها معمليا ؟
- 7. شكل (6-9) يبين محول شفرات رباعية إلى سباعية ، ماذا يحدث لو استخدمنا محول شفرات خماسية إلى سباعية بدلا منه ؟ اكتب قائمة العمليات الجديدة بعدد العمليات الاضافية ؟
- 8. هل مسجل التراكم الموجود فى شكل (6-11) يقوم بنفس دور مسجل الستراكم فى أى معالج من حيث أنه يكون طرفا فى أى عملية حسابية أو منطقية والنتيجة تخزن فيه ؟
- 9. ما مقدار الذاكرة التي يستطيع المعالج الافتراضي الموجود في شكل (6-13) أن يتعامل معها ؟ وكيف نزيد هذه الكمية ؟
- 10. لو أردنا إضافة مسجل أو امر للوحدة الموجودة في شكل (6−13) فأين يكون ،
   وضح ذلك ؟

# الفصل السابح

أساسيات مواجمة المعالج

Fundamentals of Microprocessor Interfacing

#### 1-7 مقدمة

مهمتان أساسيتان تستطيع عملهما باستخدام المعالج: المهمة الأولى هى أنه أتستطيع برمجته لحل أى مشكلة إذا كان كل ما تطلبه هذه المشكلة هو البرمجة فقط (software). المهمة الثانية التى تستطيع عملها باستخدام المعالج هي أنك تستطيع مواجهته مع بعض الدوائر الخارجية للوصول إلى الكثير من الأغراض والتى سنذكر منها اثنين فقط على سبيل المثال لا الحصر:

1. تستطيع مواجهة المعالج مع بعض الدوائر الخارجية مثل دوائر الذاكرة وبوابات الإدخال وبوابات الإخراج لعمل حاسب شخصى للأغراض العامة مثل الحاسبات التي نراها كثيرا في حياتنا اليومية والتي ما منها حاسب إلا قائم أساسل على معالج معين .

2. إنك تستطيع مواجهة المعالج مع بعض الشرائح الخارجية مثل شرائح الذاكوة وبوابات الإدخال والإخراج للحصول على نظام تحكم في عملية صناعية معينة. لكي يتم التحكم في أي عملية صناعية باستخدام المعالج (كالتحكم في مي سرعة محرك مثلا) ليس من الضروري أن نضع بجوار هذه العملية كومبيوتر متكامل باهظ الثمن لإتمام عملية التحكم ولكننا نستطيع بناء دائرة مبسطة علي كارت واحد مكونة من المعالج وعدد قليل من الشرائح الموصلة عليه لاستيفاء هذا الغرض وبأقل التكاليف الممكنة.

إننا فى هذا الفصل وقبل أن ندخل فى تفاصيل عملية مواجهـــة أى معـالج مــع الدوائر الخارجية سنحاول أولا التعرف على بعض الأساسيات الضرورية والتــى يجب أن نأخذها فى الاعتبار قبل البدء فى عملية المواجهة مع أى معالج.

# 2-7 فصل خطوط المعالج Buffering of microprocessor lines

## 7-2-7 ماذا نعنى بكلمة فصل ؟

إن الفصل يكون عادة بين شيئين ينتج من اتصالهما المباشر بعصض المشاكل ، لذلك فإننا نضع بينهما وسيطا يكون حلقة الوصل بين هذين الشيئين . وأقرب مثال على ذلك ما نسمعه في عصرنا الحالى الملىء بالحروب عن وجود منطقة فاصلة بين القوتين المتحاربتين تتمركز فيها قوات محايدة تكون حلقة الوصل بين القوتين . هذا الموقف ينشأ في الكثير من الدوائر الإلكترونية عند تحميل إحداها على الأخرى . ماذا يحدث لو أن الدائرة المصدر كانت غير قادرة على إدارة driving أو تشغيل الدائرة الحمل بسبب أن الدائرة الحمل تحتاج إلى الكثير من التيار الذي لا تستطيع الدائرة المصدر توفيره ؟ الذي يحدث هو أن جهد خرج

الدائرة المصدر يضمحل أو يتلاشى وبذلك تصبح الدائرة غير قادرة على إدارة الحمل . في هذه الحالة يكون الحل هو استخدام فاصل Buffer بين الدائرتين ويكون هذا الفاصل عبارة عن دائرة الكترونية (وليس قوات أمم متحدة) تستطيع الدائرة المصدر إدارتها وتستطيع هي إدارة الدائرة الحمل ، ونؤكد هنا على أن الدائرة الفاصلة تكون دائرة يستطيع المصدر إدارتها وإلا فليس هناك أي معنى لاستخدامها كفاصل لأنها في هذه الحالة ستحتاج إلى فاصل . شكل (7-1) يبين عملية الفصل بين دائرتين باستخدام دائرة فصل .

# 2-2-7 متى نحتاج لفصل buffering خطوط المعالج ؟

من المعروف وكما سنرى في الفصول القادمة أن جميع خطوط المعالج الخارجة منه توصل على الكثير من الدوائر أو الشرائح الإلكترونية على التوازى ، فمتلا خطوط العناوين توصل على العديد من شرائح الذاكرة سواء RAM أو ROM والعديد من بوابات الإدخال وبوابات الإخراج . جميع هذه الشرائح تعتبر أحملا بالنسبة للمعالج عليه الوفاء باحتياجاتها من التيار ، فعندما يكون خط العنوان الخارج من المعالج طابع واحد فإن هذه الشرائح ستسحب تيارا معينا من المعالج لابد وأن يستطيع توفيره ، وعندما يكون خط العنوان الخارج من المعالج المعالج عليه فإن هذه الشرائح ستصرف تيارات معينة لابد وأن يكون المعالج قادرا على صرفها أو بلعها .



بتجميع هذه التيارات الداخلة والخارجة على الخطوط المتناظرة لجميع الشرائح الموصلة على المعالج يمكننا أن نعرف كم من التيار يجب على شريحة المعالج أن توفرها للشرائح الخارجية في حالة high وكم من التيار يجب أن تستقبلها أو تصرفها sinking في حالة low بعد حساب مجموع التيارات المطلوب توفيرها أو صرفها من المعالج يقوم المصمم بالنظر في الكتالوج الخاص بشريحة المعالج لمعرفة هل سيستطيع الوفاء بهذه الأغراض أم لا ؟ بناء على ذلك سيأخذ المصمم قراره بالحاجة إلى فاصل أم لا بناء على المواقف التالية :

1. إذا وجد المصمم أن احتياجات الأحمال من التيار ليست أقل مما يستطيع

المعالج توفيره وبكمية كافية كعامل أمان فإنه في هذه الحالة لابد من اللجوء إلى استخدام فاصل buffer ، ويجب على المصمم ألا يضع نفسه في المنطقة الحرجة كأن يهمل استخدام الفاصل إذا وجد أن التيارات التي تحتاجها الأحمال أقل أو تكاد تساوى ما يستطيع المعالج الوفاء به ، بل يجب عليه أن يعطى نفسه عامل أمان كافي لأن ذلك بالطبع سيؤثر على تشغيل الدائرة فيما بعد .

2. إذا كانت المسافة بين الحمل والمعالج طويلة بحيث سيحتاج الوضع لاستخدام اسلاك توصيل cables طويلة لإتمام عملية التوصيل ، فإنه في هذه الحالة لابد من استخدام دائرة فصل عند الخروج من المعالج وقبل السلك . إن ذلك ناشيئ من الطبيعة السعوية لسلك التوصيل ، فمثل هذه الأسلك تكون لها سعة من الطبيعة السعوية لسلك التوصيل ، فمثل هذه الأسلك تكون المعالج وتشوهها وبالذات في مثل هذه التطبيقات التي تكون الموجات المربعة هي المستخدمة عادة وحيث تكون ترددات هذه الموجات عالية بحيث تتأثر بمثل هذه السعة الناشئة عن السلك . شكل (7-2) يبين موجة مربعة وقد حصل لها تشويه بسبب السعة الطفيلية parasitic capacitance السلك . لذلك فإنه عامة نستطيع القول أنه إذا كان الحمل موجودا على كرت غير الكرت الذي عليه المعالج فإنه في هذه الحالة يستحسن استخدام فواصل buffers على جميع المسارات بعد المعالج مباشرة .



3. هناك بعض المعالجات التى تستخدم فكرة المزج الزمنى multiplexing بين مساراتها مثل المعالج 8085 الذى يستخدم الثمانية خطوط الأولى من مسار العناوين كمسار للبيانات أيضا بحيث أن هذه الخطوط تحمل إشارة عناوين لمدة معينة من الزمن ثم بعد ذلك تحمل إشارة بيانات كما سنرى ذلك بالتفصيل في الفصل القادم . لمثل هذه المعالجات لابد من إجراء عملية عزل لإشارة البيانات وحدها لتكون على مسار خاص و لإشارة العناوين وحدها لتكون على مسار أخو وذلك قبل توصيل الأحمال على هذه المسارات . إذا كان ذلك سيتم فإنه عادة وذلك قبل توصيل الأحمال على هذه المسارات . إذا كان ذلك سيتم فإنه عدادة

يستخدم شرائح تقوم بعملية عزل أو فصل للإشارات كل على مسار خاص وفى نفس الوقت تكون هذه الشرائح فواصل buffers تفى باغراض الأحمال من التيارات .

الآن إذا تم أخذ القرار بأنه لابد من استخدام الفواصل فهناك بعض الملاحظ التى التي يجب أن تؤخذ في الاعتبار عند اختيار الشريحة التي ستستخدم كفاصل لأن هناك الكثير من الشرائح التي تستطيع القيام بهذه المهمة:

- ا. بالطبع كما ذكرنا فإن الفاصل buffer الذي ستستخدمه لابد وأن يكون قادرا على الوفاء بالتزامات التيار المطلوبة للأحمال وإلا فلا فائدة من استخدامه.
- 2. لابد أن يكون المعالج يستطيع إدارة جميع الفواصل المركبة على خطوطه وإلا أيضا فلا فائدة من استخدامها .
- 3. يجب ألا تؤثر الفواصل على طبيعة الإشارة فهناك مثلا فواصل من طبيعتها أنها تعكس الإشارة (تجعل الواحد صفرا والصفر واحدا) لذلك يجسب أن يؤخذ ذلك في الاعتبار إذا كانت مثل هذه الفواصل سوف تستخدم.
- 4. يجب أن يناسب الفاصل buffer طبيعة الإشارة التي سيتمر من خلاله ، فهناك مثلا مسارات أحادية الاتجاه بمعنى أن الإشارة عليها تمر في اتجاه واحد فقط مثل مسار العناوين الذي تكون الإشارة عليه دائما من المعالج إلى الأجهزة الخارجية لذلك يجب على الفاصل أن يسمح بذلك ، كذلك فإن من طبيعة مسار البيانات أن الإشارة عليه تمر في كلا الاتجاهين من وإلى المعالج لذلك أيضا يجب على الفاصل المستخدم أن يأخذ ذلك في الاعتبار .

# 1-7 البوابات ثلاثية المنطق Tristate logic gates

إن أى مسار من مسارات المعالج يكون عبارة عن مجموعة من الخطوط المتوازية التي أصلها ، أى تخرج من المعالج ، وموصل عليها على التوازى الكثير من الأجهزة الخارجية مثل شرائح RAM و ROM وبوابات الإدخال والإخراج . من هذه المسارات مسار البيانات الذى يتكون من ثمانية خطوط في بعض شرائح المعالجات التي ندرسها في هذا الكتاب . شكل (7-3) يبين هذا المسار خارجا من المعالج وقد وصل عليه الكثير من الأجهزة المحيطة .

فى حالة المنطق الثنائى سنجد أن جميع هذه الأجهزة لابد وأن يكون خرجها إما صفرا أو واحدا . لذلك فإنه من الممكن أن يكون الخط DO متلك مسار البيانات عليه صفرا من خرج ال RAM وفى نفس الوقت يكون عليه واحدا من خرج ال ROM ، وكما نعلم فإن الواحد المنطقى فى نظام ال TTL يعنى جهدا أكثر من 2.4 فولت والصفر المنطقى يعنى جهدا أقل من 0.4 فولت ووجود هذين

الجهدين على نفس الخط وفى نفس الوقت يعنى قصر كهربى short circuit مما سينتج عنه تخريب لمرحلة الخرج فى أحد الجهازين إن لم يكن كليهما . شكل (4-7) يبين خط البيانات DO وقد حدث عليه هذا القصر short circuit نتيجة توصيل الجهازين اللذين خرجهما عبارة عن مرحلة تتائية المنطق التى تكون إما صفر أو واحد .





## الآن ما هو الحل لهذه المشكلة ؟

إن هذه المشكلة يمكن أن تتلاشى إذا استخدمنا فى مرحلة خرج هدده الأجهزة بوابات ثلاثية المنطق بدلا من البوابات ثنائية المنطق التى نتجست عنها هذه المشكلة . لكى نفهم تركيب البوابات ثلاثية المنطق سنأخذ نظرة سريعة على

تركيب البو ابات ثنائية المنطق ولكن قبل ذلك يجب أن نعى جيدا أن هذه المشكلة مصاحبة فقط للأجهزة التى تقوم بإدخال معلومات إلى المعالج من خلل مسار البيانات مثل بو ابات الإدخال و ال RAM و ال ROMI ، و أما الأجهزة التى تستقبل معلومات من المعالج مثل بو ابات الإخراج فلا تعانى من هذه المشكلة .

#### 1-3-7 بوابات المنطق الثنائي Double state logic gates



شكل (7-5) يبين تركيب ورمز بوابة من البوابات ثنائية المنطق و هي بوابة من NOT . هذه البوابة دائما يكون خرجها إما واحدا أو صفرا علي حسب حالة الدخل . إذا كان الدخل يساوى واحدا H فإن الترانزيستور T4 يكون مجمعه وبالتالى فإن T3 يكون ON ويكون باعثه H مما يجعل T3 يكون ON وبالتسالى فإن الخرج يكون موصلا إلى الأرضى أى يكون الخرج صفرا في هذه الحالية. لاحظ أن T1 في هذه الحالة يكون T3 أي غير موصل ولذلك فإن الخرج يكون T4 معزو T4 من مصدر الجهد T5 . إذا كان الدخل صفرا T5 وبالتالى T5 يكون T5 مما يجعل T5 يكون T5 وبالتالى T5 يكون T5 مما يجعل T5 يكون متصدر الجهد T5 ويكون موصل واحدا أى T5 واحدا أى الدول ألم الموقت ينفصل عن الأرضى .

## 7-3-7 البوابات ثلاثية المنطق Tristate logic gate



تتميز البوابة ثلاثية المنطق أن لها طرفا ثالثا خاصا بالتحكم في الخرج بحيث إذا كان هذا الطرف فعالا فإن البوابة ثلاثية المنطق تسلك نفس مسلك البوابة ثنائيية المنطق تماما ، وأما إذا كان طرف التحكم غير فعال أو خامل فإن خرج البوابية ثلاثية المنطق يأخذ حالة جديدة غير معروفة في البوابات ثنائية المنطق وهي أن الخرج لا يكون صفرا ولا واحدا وإنما يكون مفتوحا open circuit أو مقاومة عالية جدا high impedance .

شكل (7-6) يبين الدائرة الإلكترونية والرمز المستخدم لمرحلة خرج بوابة تلاثية المنطق وقد تم التحكم فيها عن طريق خط التشييط enable . لاحظ أن مرحلة الخرج هذه هي نفسها مرحلة الخرج التي تم شرحها في شكل (7-5) ولكن مضاف عليها الترانزيسترات T7, T6, T5 التي تعمل كمفاتيح يتم التحكم فيها عن طريق خط التشيط عاليا H فإن البوابة فيها عن طريق خط التشيط عاليا فإن البوابة تعمل يكون OFF كل منهما يكون OFF وبالتالي فإن البوابة تعمل كبوابة ثنائية المنطق مثل التي شرحت سابقا في شكل (7-5) بحيث إذا كان الدخل H فإن الخرج يكون L والعكس . أما إذا كان خط التنشيط خاملا فيان كلا من T7 يكون OFF مما سيجعل T6, T5 كل منهما يكون غير موصل لا على الأرضي و لا T7 يكون OFF وبالتالي فإن الخرج يكون غير موصل لا على الأرضي و الكي المنطق مقاومة عالية.

السؤال الآن كيف ستستخدم البوابات ثلاثية المنطق في الحماية من القصر الكهربي short circuits الذي يحدث بسبب توصيل أكثر من جهاز عليي نفس خطوط المسارات كما أوضحنا في شكل (7-4) ؟

إن جميع الأجهزة التي ستوصل على مسار البيانات للمعالج يجب أن تكون مرحلة الخرج فيها عبارة عن بوابات ثلاثية المنطق وعن طريق خطوط التنشيط لكل جهاز فإن المعالج سيجعل جميع الأجهزة في حالة خمرول أي أن خرجها سيكون كما لو كان غير موصل على المسار إلا جهازا واحدا فقط وهو الجهاز الذي يتعامل معه المعالج في تلك اللحظة . أي أنه نتيجة استخدام هذا النوع من البوابات فان يكون هناك غير جهاز واحد فقط هو الفعال في أي لحظة وهو الذي يتعامل معه المعالج وهو الذي سيكون موصلا على مسار البيانات وأما بقية الأجهزة فستكون منفصلة عن مسار البيانات نتيجة أن خط التنشيط الخاص بها غير فعال . شكل (7-7) يبين عملية توصيل أكثر من جهاز على مسار البيانات باستخدام البوابات ثلاثية المنطق .



شكل (7-8) يبين الأنواع المختلفة للبوابات ثلاثية المنطق. هناك مثلا البوابات التي يكون خرجها مثل دخلها تماما إذا كان خط التشيط فعالا ، كما أن هناك البوابات التي يكون خرجها عكس دخلها إذا كان خط التنشيط فعالا . هناك أيضا البوابات التي يكون خط تنشيطها فعالا عندما يكون صفرا ، وأخرى يكون خط تنشيطها فعالا عندما يكون واحد . مهمتك أنت كمصمصم هي اختيار البوابة المناسبة للتطبيق الذي تستخدمه .



#### Latch الماسك 4-7

في بعض التطبيقات تتطلب عملية الفصل استخدام مكونات لها خاصية مسك المعلومة على خرجها بالرغم من فقدان هذه المعلومة على الدخل . إن البوابات ثلاثية المنطق ليست لها هذه الخاصية لأنها طالما أن خط التنشيط فعال تكون هناك معلومات معينة على الخرج وبمجرد أن يكون خط التشيط غير فعال فيان المعلومة التي على الخرج تفقد تماما . إن الماسك عبارة عن قلاب flip flop . وغالبا ما يكون من النوع D بحيث أن المعلومة التي على طرف الدخل D تنتقل إلى الخرج Q بعد وجود نبضة على طرف الترامن CK . تظل المعلومة الموجودة على الخرج كما هي لا تتغير حتى لو تغير الدخل D طالما أنه لم تعط أى نبضة تزامن أخرى ، لذلك فإننا نقول إن المعلومة قد مسكت على الخرج . شكل (7-9 أ) يبين مثل هذا الماسك . هناك أيضا الكثير من التطبيقات (أجهزة إدخال البيانات إلى المعالج مثلا) كما سنرى والتي تتطلب وجود بوابــة ثلاثيــة المنطق بعد الماسك لتكون بمثابة فاصل بين مسار البيانات وخرج الماسك وذلك لأن الماسك وحده لا نستطيع توصيله على مسار البيانات مباشرة لأن خرجه يأخذ أحد الحالتين فقط إما الصفر أو الواحد أي ثنائي المنطق . ولذلك فإنه عادة يوضع بعد الماسك بوابة ثلاثية المنطق بحيث يوصل خرج الماسك على مسار البيانات فقط عندما يكون خط تتشيط البوابة ثلاثية المنطق فعالا . شكل (7-9ب)

يبين دائرة ماسك متبوعة ببوابة ثلاثية المنطق.



## 7-5 بعض الشرائح التي تستخدم في فصل المسارات

سنعرض في هذا الجزء لمكونات بعض الشرائح التي يمكن استخدامها في عملية عزل المسارات ويجب أن نؤكد على أنه ليست هذه فقط هي الشرائح المتاحة ولكن هناك الكثير غيرها يمكن استخدامه ، فقط مطلوب قراءة كتالوجات هذه الشرائح وفهمها قبل البدء في استخدامها .

### 7-5-1 الشريحة 74244 عازل ثماني ثلاثي المنطق أحادي الاتجاه

بالنظر إلى الرسم الوظيفي والطرفي الموضحان في شكل (7–10) يتضـــ لنا كيفية عمل هذه الشريحة . لاحظ أيضا أن هذه الشريحة أحادية الاتجــاه ، أى أن الإشارة يمكن أن تمر فيها في اتجاه واحد فقط على عكس الشريحة 74245 التـي سيأتي شرحها . هذه الشريحة تحتوى على ثماني بوابات ثلاثية المنطق مقســمة إلى مجموعتين ، المجموعة الأولى مكونة من 4 بوابات لها خط التنشيط الخـاص بها على الطرف رقم 1 والمجموعة الثانية مكونة من الأربع بوابــات الأخـرى والتي لها خط تنشيط خاص بها هي الأخرى على الطرف رقـم 19 . لاحـظ أن خطوط التنشيط (1 و 19) تكون فعالة عندما تكون صفرا ، ولذلك فقد تم وضــع شرطة فوق اسم كل منها ( $\overline{OEb}$ ) . كما نعلم عن البوابات ثلاثية المنطـق فإنه طالما أن خط التنشيط فعال (صفر في هذه الحالة) فإن الموجود على دخــل

هذه الشريحة ينتقل إلى خرجها . إن هذه الشريحة تصلح فقط لعزل خطوط مسار العناوين وذلك لأن الإشارة التى على هذا المسار تكون دائما خارجة من المعالج إلى الأجهزة المحيطة ولا تأخذ الاتجاه العكسى على الإطلاق .



### 7-5-7 الشريحة 74245 عازل ثماني، ثلاثي المنطق، ثنائي الاتجاه

هذه الشريحة عبارة عن عازل buffer ثنائي ، الاتجاه أي يمكنها إرسال واستقبال المعلومات ، وخرجها ثلاثي المنطق غير عاكس ولها خط تحكم في الاتجاه وهو

الطرف رقم 1 . الطرف رقم 19 هو خط تتشيط أو فعالية الشريحة الذي يكــون فعال عندما يكون صفر Chip Enable, CE . شكل (7-11) يبين الرسم الطرفي والوظيفي للشريحة . عندما يكون الطرف 19 فعالا (صفر) فإن الشريحة تكـون نشطة ، وعندما يكون هذا الطرف خاملا (واحد) فإن الشريحة تكون خاملــة ولا تعمل . الطرف 1 يتحكم في اتجاه البيانات خلال الشريحة . فعندما يكـون هـذا الطرف واحد فإن الإشارات تمر في الاتجاه من A إلى B ، وأما إذا كـان هـذا الخط صفر فإن الإشارة تمر في الاتجاه من B إلى A . لذلك فإن هذه الشــريحة مناسبة جدا لفصل خطوط مسار البيانات كما سنرى .



#### 7-5-7 الشريحة 74374 عازل ماسك ذو ثماني بتات

تحتوى هذه الشريحة على ثمانية قلابات من النوع D كلّها موصلة على نفس طرف التزامن CK وهو الطرف رقم 11 في الشريحة . عند إعطاء نبضة تزامن على هذا الطرف تتقل الإشارة الموجودة على جميع أطرب النخرج طالما لم يتم إعطله الخرج المناظر Q ، وتظل هذه الإشارة ممسوكة على الخرج طالما لم يتم إعطله أي نبضات تزامن أخرى . كل واحد من هذه القلابات موصل على بوابة ثلاثية المنطق تسمح بمرور الإشارة إلى أطراف الخرج عندما يكون طرف التشيط (الطرف  $\overline{OE}$  فعالا (صفر) . سنرى بعد قليل كيفية استخدام هذه الشريحة في فصل مسار العناوين للمعالج 8085 بالذات لطبيعة مساراته . شكل ( $\overline{OE}$ ) يبين الرسم الطرفي و الوظيفي لهذه الشريحة .



# الفصل الثامن

فصل مسارات المعالجات Buffering of Microprocessor Buses

#### 8-1 مقدمة

كما رأينا في الفصل السابق فإن أي مسار bus يكون عبارة عن مجموعة مــن الخطوط المتوازية والتي عليها يمكن نقل معلومات أو إشارات من مكان لأخر . عادة تكون هذه المعلومات أو البيانات خارجة من مصدر معيسن وقساصدة إلى هدف آخر . بعض هذه المسارات يكون أحادى الاتجاه مثل مسار العناوين الـذي دائما يحمل إشارات من المعالج إلى الأجهزة المحيطة ، والبعض الآخر يكون ثنائي الاتجاه مثل مسار البيانات الذي تكون عليه الإشارة خارجة من المعالج إلى الأجهزة المحيطة في أزمنة معينة أو العكس من الأجهزة المحيطة إلى المعـــالج في أزمنة أخرى . إن الهدف من عملية مواجهة المعالج مع الأجهزة المحيطة هو توفير الوسائل التي يستطيع بها المعالج التخاطب مع هذه الأجهزة ونعنى بكلمـــة التخاطب إرسال واستقبال معلومات أو إشارات إلى ومن هذه الأجهزة . شكل (1-8) يبين شريحة معالج وقد خرج منها مسار للبيانات إلى جميع الأجهزة المحيطة ، فهل هذا يكفي لحل جميع مشاكل عملية المواجهـة ؟ كمثال على الأجهزة المحيطة نرى في هذا الشكل بوابة إدخال وبوابة إخراج وذاكرة قـراءة وكتابة RAM وذاكرة قراءة فقط ROM . لاحظ في هذا الشكل أن المعالج كما لو كان بنكا أو دكانا للمعلومات وجميع الأجهزة المحيطة تريد التعامل معه من خلال مسار البيانات .

عند مواجهة (توصيل) المعالج مع أى جهاز من الأجهزة المحيطة تتشأ مشكلتان يجب التغلب عليهما وهما كما يلى:

أولا: يجب التأكد من أنه في أي لحظة لا يتم نقل أي معلومة إلا لجهاز واحد فقط ، أي أنه عندما يكون المعالج في حالة اتصال (مخاطبة) مع أي جهاز مرن الأجهزة المحيطة فإنه يكون على اتصال بهذا الجهاز فقط دون الأجهزة الأخرى. فمثلا نريد أن نضمن أنه عندما سيرسل المعالج معلومة إلى أي بوابة إخراج فإن هذه المعلومة لن تذهب أيضا إلى أي بايت من بايتات ال RAM .

ثانيا: المشكلة الثانية هي أنه يجب التأكد من أنه عند اتصال المعالج بأى واحد من الأجهزة المحيطة فإن الأجهزة الأخرى لن تشوش أو تتداخل في عملية الاتصال . فمثلا عندما يريد المعالج أن يقرأ معلومة من ال RAM فإننا نريد أن نضمن أن ال ROM أو أي بوابة إدخال لن تتدخل وترسل هي الأخرى معلومات إلى المعالج بحيث يحدث في هذه الحالة ما يسمى بتصادم للمعلومات على مسلر البيانات وقد أشرنا لذلك في الفصل السابق في معرض حديثنا عن البوابات ثلاثية المنطق .



8-2 لماذا مسار العناوين ؟

إن المشكلة الأولى وهي مشكلة ضمان الاتصال أو التعامل مع جهاز واحد فقط يمكن التغلب عليها عن طريق استخدام مسار للعناوين بحيث يكون لكل جهاز من الأجهزة المحيطة عنوانا خاصا به يتم إخراجه على مسار العناوين من المعالج و لا يتعرف على هذا العنوان إلا الجهاز المعنى به فقط فيصبح هذا الجهاز (الذي تعرف على عنوانه) في حالة نشاط أو فعالية فيستقبل المعلومة الموجسودة على مسار البيانات . وأما جميع الأجهزة الأخرى التي لم تتعرف على العنوان فإنــــها تكون خاملة ويتم منعها من التعامل مع مسار البيانات ، لذلك ظهرت الحاجة إلى مسار للعناوين بجانب مسار البيانات . شكل (2-8) يبين مسار العنساوين وقد أضيف إلى النظام الموجود في شكل (١-٥) . عادة يتكون مسار العناوين من عدد معين من الخطوط ويتم تحديد هذا العدد عن طريق مصمم (صانع) شريحة المعالج . هذا المسار سيحمل إشارة ثنائية (وحايد وأصفار) وكل إشارة تمثل شفرة أو كودا لعنوان واحد من الأجهزة المحيطة التي يستطيع المعالج التعامل معها . لذلك فإن عدد هذه الأجهزة يساوى اثنين أس عدد الخطوط الموجودة في مسار العناوين ، فلو كان مثّلا عدد خطوط مسار العناوين يساوى ستة خطوط فإن عدد الأجهزة سيكون 64 جهازا ( $^{6}2$ ) . إن بعض شرائح المعالجـــات التــى سنتعامل معها في هذا الكتاب يحتوى مسار العناوين فيها على 16 خطال أو 16 بت ، ولذلك فإنها تستطيع التعامل مع 216 أي 65536 جهازا أو عنوانا من الأجهزة المحيطة بين بوأبات إدخال وبوابات إخراج وبايتات ذاكرة كل منها لــه العنوان الخاص به والمكون من 16 بت.



كما رأينا فإن نظام العنونة (كما في شكل (8-2) والذي سيأتي تفصيله فيما بعد) قد حل المشكلة الأولى وهي مشكلة ضمان عدم تعامل المعالج مع أكثر من واحد من الأجهزة المحيطة . أما المشكلة الثانية وهي عدم التداخل بين الأجهزة المحيطة على مسار البيانات أو عدم تصادم المعلومات على نفس المسار فهذه قد أوضحنا في الفصل السابق أن سببها يرجع إلى استخدام البوابات تتائية المنطق في مراحل خرج الأجهزة المحيطة ، ولقد أوضحنا في الفصل السابق أيضب أن حل هذه المشكلة يكون عن طريق استخدام البوابات ثلاثية المنطق في مراحل خرج هذه الأجهزة بحيث عندما يريد المعالج التعامل مع أي جهاز فإنه يقوم بتتشيط خط التحكم في مرحلة خرج هذا الجهاز فقط وأما باقي الأجهزة الموصلة على مسار البيانات فتكون خاملة أو كما لو كانت غير موصلة على مسار البيانات open circuit . شكل (3-8) يبين عملية توصيل الأجهزة المحيطة مصع المعالج وقد استخدم منتخب أو فاكك أو محلل شفرة ملحق بكل جهاز بحيث يصبح خرج هذا المحلل فعالا إذا كان العنوان الموجود علي مسار العناوين مطابقا تماماً للعنوان الذي صمم من أجله هذا المحلل ، حيث في هذه الحالة يكون هذا هو الجهاز الوحيد الذي سيتعامل مع المعالج . إن عملية تصميم منتخصب أو محلل شفرة لكل جهاز من الأجهزة المحيطة سنتعرف عليها بالتفصيل في الفصول القادمة في معرض الحديث عن مواجهة الذاكرة وبوابات الإدخال والإخراج.



## 8-3 لماذا مسار التحكم ؟

افترض مثلا أن المعالج يريد كتابة (إرسال) المعلومة أو الرقم 55H إلى البايت التي عنوانها E100H ، فماذا سيفعل المعالج على ضوء معرفتنا بوظيفة كل من مسار العناوين والبيانات ؟ إن المعالج لكى يقوم بهذه المهمة فإنه سيضع العنوان وبذلك تصبح شريحة الذاكرة التسى تحتوى هذه البايت نشطة وعلى استعداد التعامل مع المعالج ، عند ذلك يقوم المعالج بوضالمعلومة 55H على مسار البيانات فتتلقاها البايت المعنية وتسجل فيها . المشكلة هنا هي أن المعالج عندما قام بتتشيط شريحة الذاكرة التي تحتوى هذه البايت السعلم يخبر الشريحة عما إذا كان سيرسل إليها معلومات أم سيستقبل منها ، أى هل سيكتب فيها أم سيقرأ منها . لذلك كان من الضرورى أن يكون هناك خط تحكم يخرج من المعالج يخبر الجهاز الذي سيتعامل معه المعالج عن الهدف من هذا التعامل ، هل هو بغرض القراءة أم بغرض الكتابة . مثل هذا الخسط وخطوط أخرى تجمع تحت اسم مسار التحكم ومددا لخطوط في هذا المسار يختلف من معالج لآخر . سنذكر هنا أهم أربعة خطوط تحكم وسينترك الباقي

للكلام عنه في مواضع استخدامه .

#### من خطوط التحكم ما يلى:

- خط قراءة الذاكرة memory read, MEMR وهذا الخط يقوم المعالج بتنشيطه في حالة القراءة من الذاكرة (RAM) .
- 2. خط الكتابة في الذاكرة memory write, MEMW وهذا الخط يقوم المعالج بتنشيطه في حالة الكتابة في الذاكرة (RAM) .
- 4. خط كتابة في بوابة إخراج output port write, IOW وهذا الخط يكون فعالا علاما يكون المعالج في حالة إرسال للمعلومات إلى بوابة إخراج .

لاحظ أن واحد فقط من هذه الخطوط (خطوط التحكم) يكون فعالا في أى لحظة وباقى الخطوط تكون خاملة ولذلك فإن تسمية هذه المجموعة من الخطوط بالمسار تعتبر تسمية مجازية ومن الصواب أن تسمى خطوط التحكم فقط ولكن جرى العرف على إطلاق اسم مسار التحكم عليها . شكل (8-4) يبين شريحة معالج وقد خرج منها المسارات الثلاثة : العناوين والبيانات والتحكم . لاحظ أن عدد خطوط مسار العناوين 16 خطا في بعض المعالجات التي ندرسها في هذا الكتاب (وهي المعالجات ذات 8 بت) وسيصل عدد خطوطه إلى 32 بيت كما سنرى في المعالجات الحديثة . وكذلك عدد خطوط مسار البيانات 8 خطوط فسي المعالجات ذات 8 بت وسيصل إلى 32 أيضا كما سنرى . أما عدد خطوط مسار التحكم فلم يكتب في شكل (8-4) لأن هذا العدد كما أشرنا يختلف من معالج التحكم فلم يكتب في شكل (8-4) لأن هذا العدد كما أشرنا يختلف من معالج



# 8-4 تهيئة مسارات المعالج 8085 لعملية المواجهة

| AD2 14 27 A14 AD3 15 26 A13 AD4 16 25 A12 AD5 17 24 A11 AD6 18 23 A10 AD7 19 22 A9 Vss 20 21 A8 | AD4<br>AD5<br>AD6<br>AD7 | 15<br>16<br>17<br>18<br>19 | المعالج 808 | 25<br>24<br>23<br>22 | A12<br>A11<br>A10<br>A9 |
|-------------------------------------------------------------------------------------------------|--------------------------|----------------------------|-------------|----------------------|-------------------------|
|-------------------------------------------------------------------------------------------------|--------------------------|----------------------------|-------------|----------------------|-------------------------|

إذا ألقينا نظرة فاحصة على أطراف الشريحة 8085 كما فيى شكل (8-5) في محاولة للتعرف على المسارات المختلفة لهذا المعالج لوجدنا الآتى:

- مسار العناوين يمكن التعرف على 8 خطوط فقط منه وهى الخطوط A8 إلى A15 أما باقى الخطوط فليست موجودة بالصورة المباشرة.
  - 2. مسار البيانات أيضا من الصعب التعرف عليه بالصورة المباشرة .
- 3. ماذا تعنى الخطوط AD0 إلى AD7 هل هي خطوط لمسار العناوين أم لمسار البيانات؟
- 4. خطوط التحكم كما عرفناها مسبقا ليست موجودة أيضا بالصورة المباشرة ، ولكن الموجود هو الخطوط  $\overline{\text{MD}}$  و  $\overline{\text{WR}}$  فهل هذه الخطوط لها علاقة بخطوط القراءة من الذاكرة  $\overline{\text{MEMR}}$  التى تكلمنا عنها فى معرض الحديث عن مسار التحكم ؟

جميع هذه الأسئلة وزيادة سنجيب عنها في هذا الجزء في محاولة للحصول على

المسارات الثلاثة في الصورة المباشرة والملائمة لعملية توصيل هذا المعالج مسع الأجهزة المحيطة .

## 8-4-1 مسار العناوين للمعالج 8085

تختلف الشريحة 8085 عن الكثير من الشرائح من حيث أن كل من مسار العناوين والبيانات يستخدمان نفس الخطوط AD0 إلى AD7 في عملية مشاركة زمنية time multiplexing بحيث أن الإشارة الموجودة على هذه الخطوط تكـون إشارة عناوين في بداية كل دورة أمر ثم تكون بعد ذلك إشارة بيانات . أي أن الإشارة الموجودة على الخطوط ADO إلى AD7 تمثل عنوان للحظة وجيزة في بداية كل دورة أمر ثم تختفي إشارة العنوان وتصبح الإشارة الموجودة هي إشلرة بيانات ، ولذلك فإننا لو استطعنا مسك إشارة العناوين أثناء هذه اللحظة على ماسك لحصلنا على العنوان بالكامل AO إلى A15 . السؤال هنا هو: هل هناك وسيلة لمعرفة متى تكون الإشارة على هذه الخطوط الثمانيــة AD0 إلــى AD7 تمثل عناوين ومتى تمثل بيانات ؟ لقد أجاب البروسيسور 8085 على هذا الســؤال وأعطانا الخط ALE على الطرف 30 والذي عن طريقه يمكسن معرفة نوع الإشارة على الخطوط ADO-AD7 . إن الحروف ALE تعنى Address Latch Enable أي منشط ماسك العناوين . هذا الخط يكون واحد عندما تكون الإشكارة على الخطوط ADO-AD7 تمثل عناوين ، ويكون صفرا عندما تكون الإشارة على هذه الخطوط تمثل بيانات . بذلك نستطيع استخدام هذا الخط كخط تحكم أو خط تنشيط اشريحة ماسك تقوم بمسك أو تخزين الإشارة على الخطــوط -ADO AD7 عندما يكون الخط ALE يساوى واحدا وبذلك نكون قد حصلنا على العنوان بالكامل ADO-AD7 . شكل (8-6) يبين الخطوط ADO-AD7 وقد أدخات على الشريحة 74374 التي هي عبارة عن ماسك ثماني كما شــرحناها فـي الفصــل السابق . ولقد تم توصيل الطرف ALE من المعالج إلى طرف الستزامن clock للشريحة 74374 من خلال عاكس NOT حتى نضمن أن عملية مسك العنسوان ستتم عند نزول الخط ALE من الواحد إلى الصفر بناء على طلب المعالج . في الشكل (8-6) نلاحظ أن الخطوط A8-A15 قد أدخلت هي الأخرى على شريحة ماسك مثل الخطوط ADO-AD7 فهل هناك ضرورة لذلك ؟

في الحقيقة ليست هناك ضرورة لذلك ولكننا استخدمنا الشريحة 74374 في هذا المكان لتحقيق عملية فصل buffer لهذه الخطوط حتى تستطيع إمداد جميع الدوائر المحيطة بالتيارات اللازمة . لاحظ أن الطرف رقم 1 (ŌĒ) في الشريحة رقم 74374 وهو خط التحكم في البوابات ثلاثية المنطق الموجودة في مرحلة خرج هذه الشريحة قد تم توصيله على الأرضى حتى تكون مرحلة الخرج فعالة دائما ، أي أنه بمجرد مسك العنوان فإنه يصبح مباشرة موجدودا على خرج

الشريحة . يمكن توصيل هذا الخط بالطرف HOLD القادم من المعالج لوضع مسار العناوين في حالة المقاومة العالية عند اللزوم . شكل (8-7) يبين الستزامن الموجود بين الإشارة ALE والإشارات الموجودة على الخطوط AD0-AD7 و الإشارات الموجودة على الخطوط AD0-AD15 . لاحظ أهمية تخزين محتويات الخطوط AD0-AD6 عند الحافة الهابطة لخط التحكم ALE .



#### <u>2-4-8</u> مسار البيانات للشريحة 8085

الأن وقد تم فصل مسار العناوين وتهيئته فإن الإشارة الموجودة على الخطوط ADO-AD7 تمثل إشارة بيانات في الزمن المتبقى من دورة الأمر ، والمطلوب فقط هو عملية فصل buffer لمسار البيانات حتى يستطيع توفير التيارات اللازمة للأجهزة المحيطة الموصلة عليه . لاحظ أن مسار البيانات ثنائي الاتجاه لذلك يجب مراعاة استخدام الشريحة المناسبة له وقد أوضحنا في الفصل السابق

أنه من الشرائح المرشحة لهذه العملية الشريحة 74245 والتي سبق شرحها .





شكل (8-8) يبين عملية فصل أو تهيئة مسار البيانات . نلاجظ في هذا الشكل أن الطرف رقم 1 في الشريحة 74245 هو طرف التحكم في اتجاه الإشارة  $\overline{\mathrm{DIR}}$  ولقد تم توصيل هذا الطرف بالطرف رقم 32 في المعالج وهو طرف القراءة  $\overline{\mathrm{RD}}$  ، بحيث عندما يكون هذا الطرف ( $\overline{\mathrm{RD}}$ ) فعالا أي يساوي صفرا فإن الشريحة 74245 ستسمح بمرور البيانات من الأجهزة المحيطة إلى المعالج . بينما إذا كان الطرف  $\overline{\mathrm{RD}}$  غير فعال ، أي يساوي واحد ، فإن الشريحة 74245 ستسمح بمرور البيانات من المعالج إلى الأجهزة المحيطة . نلاحظ أيضا من شكل (8-8) أن الخط  $\overline{\mathrm{RD}}$  قبل توصيله إلى الشريحة 74245 تم فصله عن طريق توصيله من خلال عاكسين .

## 3-4-8 مسار التحكم للشريحة 8085

إن مسار التحكم المبسط يتكون كما ذكرنا سابقا من 4 خطوط فقط وهي كالتالى:

- قراءة من الذاكرة Memory read
- كتابة في الذاكرة Memory write
- قراءة من جهاز إدخال Input device read
- كتابة في جهاز إخراج Output device write

| طرف 32              | طرف 31               | طرف 34         |      |
|---------------------|----------------------|----------------|------|
| طرف 32<br><u>RD</u> | طر <u>ف 31</u><br>WR | طرف 34<br>IO/M |      |
| 0                   | 1                    | 1              | ĪŌŔ  |
| 1                   | 0                    | 1              | ĪŌW  |
| 0                   | 1                    | 0              | MEMR |
| 1                   | 0                    | 0              | MEMW |

شكل (8-9) جدول حقيقة للحصول على خطوط التحكم الأربعة للمعالج 8085

جميع هذه الخطوط فعالة عندما تكون صفرا active low ولو فحصنا أطراف الشريحة 8085 فإننا لن نجد أن هذه الخطوط الأربعة بالصورة المباشرة التسى نريدها ولكننا سنجد ثلاثة خطوط فقط وهي الخطوط  $\overline{N}$  و  $\overline{N}$  المطلوب هو الحصول على خطوط التحكم الأربعة السابقة من هذه الخطوط الثلاثة . إن السر يكمن في الطرف  $\overline{N}$  حيث أن هذا الخط يكون واحدا عندما الثلاثة . إن السر يكمن في الطرف  $\overline{N}$  حيث أن هذا الخط يكون واحدا عندما يكون المعالج يتعامل مع أجهزة إدخال أو إخراج أي ينفذ واحد من الأمريس  $\overline{N}$  أو  $\overline{N}$  أن المعالج يتعامل مع ذاكرة . ولذلك إذا كان الخط  $\overline{N}$  فعالا (1) ، وكان الخط  $\overline{N}$  من الذاكرة . أما إذا كان الخط صفرا ، فإن ذلك يعنى أن المعالج في حالة قراءة من الذاكرة . أما إذا كان الخط

 $\overline{RD}$  يساوى صفر ، والخط  $\overline{MOM}$  يساوى واحد ، فإن ذلك يعنى أن المعالج فسى حالة قراءة من جهاز إدخال . شكل (8. 9) يبين جدول الحقيقة لجميع الخطسوط الأربعة المطلوبة وحالة كل خط من الخطوط الثلاثة  $\overline{MD}$  و  $\overline{MD}$  . بعد دراسة جدول الحقيقة المبين في شكل (8. 9) يمكن بناء أكثر من دائرة يكون دخلها هو الخطوط الأربعة  $\overline{MEMR}$  و  $\overline{MOM}$  و خرجها هو الخطوط الأربعة  $\overline{MEMR}$ 

سنرى هنا طريقة الحصول على هذه الخطوط باستخدام المنتخب أو فساكك الشفرة Decoder رقم 74138 وهو عبارة عن منتخب لخط واحد مسن خطوط الخرج الثمانية Y0 إلى Y7 وهذا الانتخاب يكون على حسب شفرة توضع على خطوط الدخل الثلاثة A, B, C مشكل (B-D) يبين جدول الحقيقة لهذا المنتخب وقد تم توصيل دخوله الثلاثة على الخطوط  $\overline{RD}$  و  $\overline{RD}$  و  $\overline{RD}$ .

· IOW , IOR , MEMW ,

| INPU | ىل TT | السدة |    | الـــخرج OUTPUT |    |     |      |    |     |    |
|------|-------|-------|----|-----------------|----|-----|------|----|-----|----|
| WR   | IO/M  | RD    |    | MEMW            |    | ĪŌW | MEMR |    | ĪŌŔ |    |
| С    | В     | Α     | Y0 | Y1              | Y2 | Y3  | Y4   | Y5 | Y6  | Y7 |
| L    | L     | L     | L  | H               | H  | Н   | H    | H  | H   | Н  |
| L    | L     | H     | H  | L               | Н  | Н   | H    | H  | H   | Η  |
| L    | H     | L     | H  | H               | L  | H   | H    | H  | H   | Н  |
| L    | H     | H     | H  | H               | Н  | L   | H    | H  | H   | H  |
| H    | L     | L     | H  | H               | H  | H   | L    | H  | H   | H  |
| H    | L     | H     | H  | H               | Н  | H   | H    | L  | H   | H  |
| H    | Ħ     | L     | H  | H               | H  | H   | Н    | H  | L   | Н  |
| H    | H     | Н     | H  | H               | H  | H   | Н    | Н  | Н   | L  |

شكل (8-10) جدول الحقيقة للشريحة 74138

طبقا لهذا الشكل فإن الخط MEMR سيؤخذ من على الخرج 44 للمنتخب، والخط MEMW يؤخذ من على الخرج 41 ، وأما الخط MEMW يؤخذ من على الخرج 40 ، وأما الخط MEMW يؤخذ من على الخرج 40 ، وأما باقى خروج الخرج 40 ، والخط MEWW يؤخذ من على الخسرج 43 ، وأما باقى خسروج المنتخب فإنها غير مستخدمة . شكل (8. 11) يبين كيفية توصيل هذا المنتخب مع المعالج . لاحظ من هذا الشكل أن خطوط الخرج الأربعة تم توصيلها على الشريحة 74125 وهي فاصل buffer ثلاثي المنطق وقد وصلت جميع خطوط تنشيط البوابات بالأرضى حتى تكون هذه الخطوط في حالة نشاط دائم . يمكن عند الضرورة توصيل خطوط النتشيط هذه بالخط HOLD القادم من المعالج .

شكل (8-12) يبين المعالج 8085 وقد تم فصل buffering جميع مساراته الثلاثة وأصبحت هذه المسارات متهيئة تماما لأن يوصل عليها أى واحد من الأجهزة الخارجية مثل الذاكرة وبوابات الإدخال والإخراج كما سنزى بالتفصيل في الفصول القادمة.



# 8-5 تهيئة مسارات المعالج 280 لعملية المواجهة

بإلقاء نظرة سريعة على أطراف المعالج Z80 كما في شكل (8. 13) سنكتشف أن عملية المزج الزمني time multiplexing بين مسارى العناوين والبيانات التي كانت موجودة في المعالج 8085 غير موجودة هنا ، ولكن كل مسار متاح بصورة منفصلة عن الآخر ولذلك فإن عملية التهيئة هنا ستكون أبسط من قبل لذلك فإن كل ما سنحتاجه هنا هو عملية فصل buffer لهذه المسارات بغرض الحماية وتوفير التيارات اللازمة للأجهزة المحيطة . شكل (8-14) يبين المعللج 280 وقد تم فصل مساراته الثلاثة ، العناوين والبيانات والتحكم . بالنسبة لمسار العناوين فقد استخدمت الشريحة 4244 التي تتكون من ثماني بوابات ثلاثية المنطق لهذا الغرض ، ولقد تم استخدام شريحتان منها لتحقيق عملية الفصل لل الشريحتين قد تم توصيلهما بالأرضى مباشرة مع العلم أن هذه الخطوط يمكن توصيلها على الطرف HOLD القادم من المعالج لتحقيق عملية انفصال المعالج عن المسارات الثلاثة التي سنشرحها في موضع قادم .



بالنسبة لمسار البيانات للمعالج Z80 فقد استخدمنا نفس الشريحة 74245 التى سبق استخدامها لعملية فصل مسار البيانات فى المعالج 8085 ، هذه الشريحة كما عرفناها من قبل تتكون من ثمانى بوابات ثلاثية المنطق ثنائيسة الاتجاه أى تسمح بعملية فصل buffer الإشارات التى تمر فى اتجاهين . لقد تم التحكم فى اتجاه البيانات عن طريق توصيل الطرف  $\overline{\rm DIR}$  رقم 1 فى الشريحة 74245 بالطرف  $\overline{\rm RD}$  رقم 21 فى المعالج Z80 بحيث عندما يكون الطرف  $\overline{\rm RD}$  فعلل (0) فإن الشريحة 74245 ستسمح بمرور البيانات من الأجهزة المحيطة إلى المعالج وأما عندما يكون الطرف  $\overline{\rm RD}$  غير فعال (1) فإن البيانات ستمر فى الاتجاه الأخر.

| MREQ-I9       22 - WR         IOREQ-20       21 - RD             Z80       غال (13-8) |
|---------------------------------------------------------------------------------------|
|---------------------------------------------------------------------------------------|

شكل (8–14) يبين أيضا كيفية الحصول على خطوط التحكم  $\overline{\text{MEMR}}$  و  $\overline{\text{MEMW}}$  و  $\overline{\text{MEMW}}$  و  $\overline{\text{IOR}}$  و  $\overline{\text{IOR}}$  باستخدام دوائر NAND . لاحظ أن الطوف  $\overline{\text{MREQ}}$  يكون فعالا (0) عندما يتعامل المعالج مع الذاكرة سواء بغرض القراءة منها أو الكتابة فيها . وأما الخط  $\overline{\text{IORQ}}$  فيكون فعالا (0) عندما يتعامل المعالج مع بوابات الإدخال أو الإخراج سواء بغرض القراءة أو الكتابة أيضا .



لاحظ أن خطوط التحكم الأربعة تكون فعالة عندما تكون صفر . بذلك نكون قد انتهينا من تهيئة جميع مسارات المعالج Z80 وأصبحت جاهزة لعملية المواجهة مع الأجهزة المحيطة .

#### 6-8 تسمساريسن

- 1. ما هو المقصود من تهيئة المسارات ؟ ولماذا تحتاج المسارات إلى تهيئة؟
- 2. الأجهزة المحيطة بالمعالج إما أن تكون أجهزة الدخال (ترسل ، تستقبل) المعلومات (من ، إلى) المعالج ، أو أجهزة إخراج (ترسل ، تستقبل) المعلومات (من ، إلى ) المعالج ، أختر كلمة مناسبة مما بين القوسين .
- مسار البيانات ثتائى الاتجاه ، أى أن الإشارة عليه تكون خارجة من المعالج على بعض الخطوط ، وداخلة إليه على البعض الآخر (صح ، خطأ) أختر؟
- 4. مسار العناوين أحادى الاتجاه يحمل إشارة من الأجهزة المحيطة إلى المعالج (صح، خطأ) أختر؟
- أذاكرة التي يستطيع معالج من المعالجات تبليغ 64كيلوبايت لأن (مسار البيانات ، مسار العناوين) 16 بت ، أختر إجابة ؟
  - لماذا نحتاج لخطوط التحكم MEMR و MEMW ?
    - 7. لماذا نحتاج لخطوط التحكم IOR و IOW?
- 8. عند تنفيذ الأمر STA E100 في المعالج 8085 أي الخطوط التالية سيكون فعالا : MEMW و IOW و IOW ؟ أحتر الخط الصحيح .
- 9. عند تنفيذ الأمر MOV M,A في المعالج 8085 أي الخطوط التاليــة سـبكون فعالا :MEMW و MEMW و IOW ؟ أختر إحدى الإجابات .
- 10. عند تنفيذ الأمر IN 00 في المعالجين 8085 و Z80 أي الخطوط التالية سيكون فعالا : MEMR و OR و IOW و TOW و TOW .
- 11. عند تنفيذ الأمر OUT 00 في المعالجين 8085 و Z80 أي الخطـــوط التاليــة سيكون فعالا : MEMR و MEM و TOR و TOW ؟ أختر إحدى الإجابات .

.12

| XXX; | MVI A,89H<br>STA E100<br>IN 00<br>OUT 00<br>LXI H, E100<br>MOV B,M<br>JMP xxx | XXX: | LD A,89H<br>LD (E100), A<br>IN 00<br>OUT 00<br>LD HL, E100<br>MOV B,M<br>JP xxx |
|------|-------------------------------------------------------------------------------|------|---------------------------------------------------------------------------------|
| 808  | 35 Program                                                                    | Z    | 30 Program                                                                      |

البرنامج السابق عبارة عن حلقة لا نهائية ، ارسم شكل الإشارة مع الزمن على كل خط من الخطوط  $\overline{\text{MEMR}}$  و  $\overline{\text{IOR}}$  و  $\overline{\text{IOW}}$  في أثناء تنفيذ هـذا البرنامج ؟

13. لو نفذنا برنامج السؤال 12 مرة واحدة ، أختر الإجابة الصحيحة في كل مما يلي :

عدد نبضات الفعالية للخط MEMR سيكون (17 ، 13 ، 19) .

عدد نبضات الفعالية للخط MEMW سيكون (1 ، 1 ، 9) .

عدد نبضات الفعالية للخط IOW سيكون (17 ، 1 ، 9) .

عدد نبضات الفعالية للخط IOR سيكون (1 ، 1 ، 9) .

14. إذا كان الخط  $IO/\overline{M}=1$  والخط  $\overline{WR}=0$  فإن ذلك يعنى (قراءة ، كتابة) (فى ، من) (ذاكرة ، بوابة إدخال ، بوابة إخراج) أختر الإجابة الصحيحة ؟

15. إذا كان الخط  $\overline{M}=10$  والخط  $\overline{RD}=0$  فإن ذلك يعنى (قراءة ، كتابة) (فى ، من) (ذاكرة ، بوابة إدخال ، بوابة إخراج) أختر الإجابة الصحيحة ؟

16. ما المقصود بالمشاركة الزمنية بين خطوط البيانات وخطوط العناوين في المعالج 8085 ؟ وما الهدف منها ؟

17. هل هذه المشاركة موجودة في المعالج Z80 ؟

18. اشرح دور الخط ALE في عملية فصل إشارة العناوين عن إشارة البيانات على الخطوط ADO-AD7 في المعالج 8085 ؟

19. آشرح كيفية الحصول على خطوط التحكم الأربعة في المعالج 280 ؟

# الفصل التاسح

مواجعة الذاكرة Memory Interfacing

#### 9-1 مقدمة

إن ذاكرة الكومبيوتر تكون عادة ذاكرة إليكترونية أى أن طريقة مسك المعلومة وحفظها يتم إليكترونيا ، وذلك على العكس من الأنواع الأخرى من الذاكرة مثل شرائط الكاسيت والأقراص الممغنطة والتى يتم مسك المعلومة عليها مغناطيسيا ، ونحن فى هذا الفصل لن نتعرض للتركيب الإلكترونى للذاكرة ولكن كل ما يهمنا هنا هو معرفة كيفية توصيل أو مواجه المعالج مع شرائح الذاكرة .

إن دليل التليفونات يمكن النظر إليه على أنه نوع من أنواع الذاكرة التي تسحل فيها المعلومات في صورة حروف هجائية ، وهذا النوع يماثل في الخواص ذاكرة القراءة فقط ROM والتي تستخدم في الحاسبات ، وحيث أنه يمكن قراءة المعلومات من الدليل ولكن لا يمكن تغيرها فكذلك يمكن قراءة المعلومات من ال ROM و لا يمكن الكتابة فيها ولذلك سميت بذاكرة القراءة فقط Read Only Memory . ذلك على العكس من شريط الكاسيت أو القرص الممغنط حيث يمكن تخزين المعلومات عليهما كما يمكن مسحها أو تغيرها في أي لحظة مثلها في ذلك مثل ذاكرة القراءة والكتابة في الحاسبات والتي سميت عرفا بذاكرة الاتصلل العشوائي Random Access Memory; RAM . أي نظام من نظم الحاسبات لابد وأن يحتوى على كل من النوعين من أنواع الذاكرة (ROM و RAM) حيث تحتوى ال ROM على الثوابت والبرامج المهمة لتشغيل نظام الحاسب والتي يمنع المستخدم من الدخول عليها نظرا لخطورة التغيير أو التعديك فيها ، وأما ال RAM فهي الذاكرة التي تكون متاحة للمستخدم ليقوم فيها بتخزين جميع بياناته أو برامجه في حالة تعامله مع النظام . لاحظ أن ال ROM من أهم خواصيها أنه عند انقطاع القدرة (الكهرباء) أي عند إطفاء النظام فإن جميع ما بها من معلومات لا تفقد ولكن تظل محفوظة ، وذلك على العكس من أل RAM التـــى تفقد كل محتوياتها بمجرد إطفاء النظام ، ولذلك فإنه قبل إطفاء النظام لابد مــن تخزين محتويات ال RAM التي نحتاجها على ذاكرة مستديمة مثل الشرائط أو الأقراص الممغنطة . شكل (9-1) يبين مناظرة بين ذاكرة الحاسبات والذاكرة بمعناها العام.

إن كل ذاكرة مهما كانت لابد وأن هناك طريقة معينة تسهل عملية استدعاء المعلومات منها ، فمثلا من دليل التليفونات يمكنك الوصول إلى رقم تليفون أى شخص عن طريق التسلسل الأبجدى للأحرف ، أما على شريط الكاسيت فيمكنك تحديد مكان المعلومة عن طريق عداد الشريط ، وأما فى ذاكرة الحاسب فإن كل مكان من أماكن الذاكرة محدد بعنوان وهذا العنوان عبارة عن شفرة من الوحايد والأصفار توضع على مسار العناوين فتسبب عملية تتشيط أو إثارة لمكان واحد فقط من أماكن الذاكرة ليصبح جاهزا للتعامل معه بواسطة المعالج .

| ــــــــــــــــــــــــــــــــــــــ | (1)                                |
|----------------------------------------|------------------------------------|
| الذاكرة عامة                           | ذاكرة الكومبيوتر                   |
| دليل التليفونات والاسطوانات Pick       | ROM تحتوى البرامج والثوابت         |
| up كلها أمثلة على الذاكرة التي يمنع    | التي يمنع المستخدم من الوصــول     |
| الكتابة فيسها ولكن يسمح فقط            | اليها أو العبث بها نظرا لأهميت ها  |
| بقراءتها.                              | لتشغيل النظام ويمكنه فقط أن        |
|                                        | يقرأها.                            |
| شريط الكاسيت وشريط الفيديو يمكن        | RAM يمكن للمستخدم أن يقرأ          |
| التسجيل فيهما وقراءة محتوياتهما ،      | محتوياتها ويسجل فيها ما يشـــاء ،  |
| كما يمكن المسح أو الإضافة لأي          | ويمسح ويضيف في أي مكان فيها .      |
| جزء فيهما .                            | - 1                                |
| يتم بناؤها من أوراق مثل دليل           | يتم بناء هذه الذاكرة عادة من أشباه |
| التليفون ، أو شــرائط مـن مـواد        | الموصلات ، وهي في العادة عبارة     |
| مغناطيسية مثل شرائط الكاسيت            | عن قلابات flip flops .             |
| والفيديو .                             |                                    |

شكل (9-1) مناظرة بين ذاكرة الحاسب والذاكرة عامة

### 2-9 أساسيات بناء ذاكرة الحاسب

شكل (9-2) يبين أساسيات بناء الذاكرة . يتكون مسار العناوين القادم من أي واحد من المعالجات التي ندرسها الآن من 16 خطا أو 16 بت ، ولذلك فإن كمية الذاكرة التي يستطيع المعالج أن يتعامل معها تقدر ب 162 أي 65536 بايت مرتبة كما لو كانت أرفف في دو لاب وكل رف من هذه الأرفف يمثل بايت وكل بايت أو رف تتكون من ثماني بتات أو خلايا كما في شكل (9-2) . كل واحدة من هذه البايتات تعرف بعنوان خاص بها ولذلك فإن أول بايت عنوانها هو (صفر) وآخو بايت أو آخر رف في هذا الدولاب عنوانه هو 65535 وذلك في النظام العشرى عند التعامل مع أي بايت من هذه البايتات أي القراءة منها أو الكتابة فيها فإن ذلك يكون على البايت الكاملة وليست هناك وسيلة المتعامل مع جزء من البايت ، أي عدد معين من بتاتها دون الباقي .



لاحظ أن أى شفرة على خطوط العناوين AO إلى A15 ستحدد عنوان مكان أو بايت من بايتات الذاكرة فى النظام الثنائي ، لاحظ أيضا أنه طالما أن كل بايت بتكون من ثمانى بتات فإنها تتوافق مع مسار البيانات الذى هو ثمانى بتات فإنها تتوافق مع مسار البيانات الذى هو ثمانى بتات أو ثمانية خطوط أيضا والذى سيحمل المعلومات من أو إلى هذه البايتات . بعد أن يضع المعالج عنوان البايت التى سيتعامل معها على مسار العناوين فإنه لابد وأن يحدد طريقة التعامل مع هذه البايت إذا كانت قراءة أو كتابة فيها. إذا كان المعالج يريد الكتابة فى الذاكرة فإنه يجعل خط التحكم MEMW (Memory write) وهو يخط الإعلان عن الكتابة فى الذاكرة فعالا ، أما إذا كان يريد القراءة منس يجعل خط التحكم MEMR و MEMR و MEMR و سيعل خط التحكم MEMR و MEMR و سيعل خط التحكم MEMR و MEMR فينه الذاكرة فعالا ، لذلك فإنه لزم إضافة هذين الخطين ، MEMW و MEMR في الإشارة يعنى أن هذه الإشارة تكون فعالة حينما تكون صفرا wol وهى الحالة الموجودة فى الإشارتين المستعشرية . حاول دراسة هذا الجدول وأضف من عندك شفرات لبعض العناوين الغير مذكورة فى الجدول . لاحظ أنه فى أثناء البرمجة وفى كل تعاملاتك معلى الغير مذكورة فى الجدول . لاحظ أنه فى أثناء البرمجة وفى كل تعاملاتك مع

العناوين فيما بعد سيكون في الصورة الستعشرية التي تتكون من أربع خانات كما هو مبين في شكل (9-5).

| 10.510      | 2 4 6 11                        |             | 113.     | - 1121 | 1151         |
|-------------|---------------------------------|-------------|----------|--------|--------------|
| سوده صي     | , ind                           | ,           |          | نظام   | تصام         |
| A15 الى A15 | ة الموجـــــــن<br>. ـــــــــن | سوط العناوا | <u> </u> | ستعشرى | نظام<br>عشری |
| 15 14 13 12 | 11 10 9 8                       | 7654        | 3 2 1 0  |        |              |
| 0 0 0 0     | 0 0 0 0                         | 0 0 0 0     | 0 0 0 0  | 0000   | 0            |
| 0 0 0 0     | 0 0 0 0                         | 0000        | 0 0 0 1  | 0001   | 1            |
| 0 0 0 0     | 0 0 0 0                         | 0 0 0 0     | 0 0 1 0  | 0010   | 2            |
| 0 0 0 0     | 0 0 0 0                         | 0 0 0 0     | 0 0 1 1  | 0011   | 3            |
| 0 0 0 0     | 0 0 0 0                         | 0 0 0 0     | 0 1 0 0  | 0100   | 4            |
| 0 0 0 0     | 0 0 0 0                         | 0 0 0 0     | 0 1 0 1  | 0101   | 5            |
|             | ****                            | ****        | *****    | •••••  | ******       |
| *****       | *****                           | *****       | ****     | ****** | ******       |
| 0 1 0 1     | 1 1 0 1                         | 1111        | 1011     | 5DFB   | 24059        |
| *****       | *****                           |             | ******   | *****  |              |
| 1 0 1 0     | 1 1 0 1                         | 1010        | 1 1 0 0  | ADAC   | 44460        |
|             |                                 |             | ******** |        | ,,,,,,       |
|             | •••••                           | ******      |          |        |              |
| 1 1 1 1     | 1 1 1 1                         | 1111        | 1 1 1 0  | FFFE   | 65534        |
| 1 1 1       | 1 1 1 1                         | 1111        | 1111     | FFFF   | 65535        |

شكل (9-3) عنونة الذاكرة المواجهة للمعالج

شكل (9-2) يبين أيضا كيفية الاتصال بمكان معين في الذاكرة عن طريق منتخب البايتات الموجود داخل شريحة الذاكرة . يقوم هذا المنتخب به Address منتخب البايتات الموجود داخل شريحة الذاكرة . يقوم هذا المنتخب واحد من الخطوط الموجودة على خرجه حيث يتمه هذا الاختيار على أساس الشفرة الموجودة على دخله من مسار العناوين وجعله فعالا وهذا الخط بالتالي يختار البايت المقابلة له وإما يخرج محتوياتها على مسار البيانات إلى هذه البيانات إذا كان الخط MEMW فعالا أو يدخل محتويات مسار البيانات إلى هذه البايت إذا كان الخط MEMW فعالا .

إن الزمن المأخوذ لوضع محتويات أى بايت من بايتات الذاكرة على مسار البيانات أو العكس يسمى زمن الاتصال بالذاكرة Memory access time وهذا الزمن يعتبر خاصية من خواص شريحة الذاكرة حيث يختلف فى طوله وقصره على حسب التكنولوجيا والمادة المستخدمة فى تصنيع الشريحة ، وعادة يكون هذا الزمن فى حدود المائة نانو ثانية (nano second) حيث النانو ثانية تساوى 10-9 من الثانية .

إن وحدات قياس سعة الذاكرة في عالم الحاسبات هو الكيلو بايت ك.ب KB . وتم التعارف على أن الواحد كيلوبايت يساوى 1024 بايت بدلا من 1000 التكي

تستخدم دائما مع تعريف الكيلو في الحياة العملية وذلك السهولة التعامل مع الرقم 1024 في النظام الثنائي والستعشرى . كما نعلم فإن شرائح المعالجات التي نتعامل معها لها 16 خطا للعناوين وبهذا العدد من خطوط العناوين فإنه يمكن لهذه الشريحة التعامل مع 65536 مكان من أماكن الذاكرة كما رأينا منذ قليل لاحظ أن 65536 عند قسمتها على 1024 تعطى 64 كيلوبايت لذلك يقال دائما إن هذه المعالجات يمكنها التعامل مع 64 كيلوبايت ذاكرة . شكل (9-4) يبين علاقة عدد خطوط العناوين بكمية الذاكرة التي يمكن لأي معالج أن يتعامل معها وكيف أن كمية هذه الذاكرة تتضاعف مع كل زيادة في عدد خطوط العناوين بمقدار خط واحد .

| عدد خطوط العنونة المطلوبة | كمية الذاكرة (بايت) |
|---------------------------|---------------------|
| 1                         | 2                   |
| 2                         | 4                   |
| 3                         | 8                   |
| . 4                       | 16                  |
| 5                         | 32                  |
| 6                         | 64                  |
| 7                         | 128                 |
| 8                         | 256                 |
| 9                         | 512                 |
| 10                        | 1024 (1 كيلوبايت)   |
| 11                        | 2048 (2 كيلوبايت)   |
| 12                        | 4096 (4 كيلوبايت)   |
| 13                        | 8192 (8 كيلوبايت)   |
| 14                        | 16384 (16 كيلوبايت) |
| 15                        | 32768 (32 كيلوبايت) |
| 16                        | 65536 (64 كيلوبايت) |

شكل (9-4) مضاعفة كمية الذاكرة بزيادة خطوط العناوين بمقدار خط واحد

## 9-3 كيف سنوصل الذاكرة على المعالج؟

يوجد في الأسواق العديد من شرائح الذاكرة التي تختلف من شريحة لأخرى من حيث حيث كمية الذاكرة الموجودة في كل شريحة . فهناك شرائح تحتوى الواحدة منها على واحد كيلوبايت وأخرى تحتوى الواحدة منها على 512 بايت وأخرى تحتوى الواحدة منها على 4 كيلوبايت وهكذا ، بل إن هناك شرائح تحتوى الواحدة منها على 64 كيلو بايت وأكثر ، السؤال الآن أي هذه الشرائح نستخدم للحصول على ال 64 كيلو بايت التي سنوصلها على المعالج ؟ وما هي أفضل الطرق لتوصيل هذه الشرائح ؟

#### <u>1−3−9</u> مثال توضيحي

افترض أننا في المملكة العربية السعودية ونريد الاتصال هاتفيا بالرقم 7993207 الموجود في مصر بمدينة القاهرة . إننا لكي نفعل ذلك لابد أن نضرب أو لا رقم مصر في السنترال الدولي وهو 002 ثم نضرب رقم مدينة القاهرة في مصر وهو 02 ثم نضرب الرقم الذي معنا ، أي أن الرقم كله الآن أصبح كالتالي 002027993207 . على ضوء ذلك فإننا يمكننا النظر إلى نظام التليفونات في العالم على النحو المبين في شكل (9-5) حيث يتكون هذا النظام مــن سـنترال عالمي يحتوى رقما لكل دولة من دول العالم وبمجرد ضرب رقم أي واحدة من هذه الدول فإنه يوصلك بسنترال عموم هذه الدولة الذي يحتوى رقم لكل مدينة داخل هذه الدولة ، وبمجرد ضرب رقم أي مدينة من هذه المدن فإنـــه يوصلــك بسنترال هذه المدينة الذي يحتوى جميع الأرقام داخل هذه المدينة ومنسها الرقسم الذي تريده . السؤال الآن لماذا هذا التعب في شرح نظام التليفونات وما دخله بموضوع توصيل شرائح الذاكرة على المعالج ؟ إنَّ الشبه كبير جدا بين الاثنين فكما أنك تستطيع النظر لأى رقم تليفون وتقوم بتقسيمه إلى عدة أجــزاء حيـث جزء منه يمثل الرقم الدولي وجزء يمثل رقم المدينة داخل الدولة وجزء يمثل رقم التليفون داخل المدينة فكذلك يمكن عمل نفس الشيء مع أي عنوان من عناوين الذاكرة كما سنرى بعد قليل .

#### 2-3-9 نظام بلوكات الذاكرة

أول ما سنفعله لبناء ذاكرة مقدارها 64 كيلوبايت هو تقسيم هذه الكمية من الذاكرة إلى عدد من البلوكات يحتوى كل بلوك منها على عدد من الكيلوبايتات . فمتسلا يمكننا تقسيمها إلى 64 بلوك يحتوى كل منها على واحد كيلوبايت ، أو إلى 8 بلوكات يحتوى الواحد منها على 8 كيلوبايت ، أو إلى 128 بلوك يحتوى الواحد منها على 8 كيلوبايت ، أو إلى 128 بلوك يحتوى الواحد منها على قدد البلوكات سيترك تماما للمستخدم منها على نصف كيلوبايت وهكذا فإن عدد البلوكات سيترك تماما للمستخدم

الحرية في تحديده . بمجرد تحديد عدد البلوكات سيتحدد فورا كسم خطا مسن خطوط مسار العناوين سيستخدم لتمييز البلوكات بعضها من بعض وكسم خطا سيستخدم لتمييز البايتات داخل كل بلوك بحيث ستدخل خطوط عنونة أو تمييز البلوكات على منتخب يكون خرجه 2 أس عدد هذه الخطوط بحيث سيذهب كل واحد منها لتنشيط بلوك معين .



شكل (9-6) يبين تقسيم خطوط مسار العناوين إلى خطوط عنونة بلوكات وخطوط عنونة بايتات داخل البلوكات في حالتين ، الأولى في حالة تقسيم الذاكرة إلى 64 بلوك يحتوى الواحد منها على واحد كيلوبايت ، والثانية في حالة تقسيم الذاكرة إلى 8 بلوكات يحتوى الواحد منها على 8 كيلوبايت . فسى المثال الأول الذاكرة إلى 8 بلوكات يحتوى البلوك تعناوى واحد كيلوبايت لذلك فإنه يالرم 10 طالما أن وحدة البناء وهي البلوك تعناوى واحد كيلوبايت لذلك فإنه يلزم 10 خطوط ( $^{10}$ 2 = واحد كيلوبايت) من ال 16 خطا الموجودة فسى مسار العناوين لعنونة ال 1024 بايت الموجودة داخل البلوك . أما ال 6 خطوط الباقية من مسار العناوين ( $^{6}$ 2 = 64) فإنها تستخدم في عنونة أو اختيار واحد من ال 64 كيلوبايت بلوك . المثال الثاني في شكل ( $^{6}$ 3) يبين عنونسة ذاكرة من 46 كيلوبايت باستخدام بلوكات كل منها يحتوى على 8 كيلوبايت . لاحظ أن عصدد البلوكات

يساوى 64 مقسوما على عدد الكيلوبايتات فى البلوك الواحد . إن خطوط العنونة داخل البلوك ستكون 13 خطا فى هذه الحالة حيث سيبقى ثلاثة خطوط مسن ال 16 خطا لعنونة الثمانية بلوكات . خطوط عنونة البلوكات ستنصل بمنتخب يقوم باختيار واحد من البلوكات الثمانية على حسب الشفرة الموجودة على هذه الخطوط وتسمى الخطوط الخارجة من هذا المنتخب بخطوط اختيار البلوك أو خطوط تنشيط البلوك . شكل (9-7) يبين رسما تخطيطيا لبناء ذاكرة من 64 كيلوبايت باستخدام بلوكات 8 كيلوبايت .

| خطوط مسار العناوين                                               |                                       |                               |  |  |  |  |  |  |  |
|------------------------------------------------------------------|---------------------------------------|-------------------------------|--|--|--|--|--|--|--|
| A15 A14 A13 A                                                    | .12 A11 A10                           | A9 A8 A7 A6 A5 A4 A3 A2 A1 A0 |  |  |  |  |  |  |  |
| نونة أو اختيار البلوك                                            | عشرة خطوط للعنونة داخل البلوك         |                               |  |  |  |  |  |  |  |
| ا<br>أ- عنونة ذاكرة 64 ك.ب مكونة من 64 بلوكات كل منها 1 ك.ب      |                                       |                               |  |  |  |  |  |  |  |
| A15 A14 A13                                                      | A15 A14 A13                           |                               |  |  |  |  |  |  |  |
| 3 خطوط لعنونة 8                                                  | المعنونة داخل كل بلوك 3 خطوط لعنونة 3 |                               |  |  |  |  |  |  |  |
| ا بلوكات<br>ب-عنونة ذاكرة 64 ك.ب مكونة من 8 بلوكات كل منها 8 ك.ب |                                       |                               |  |  |  |  |  |  |  |
| عنونتها                                                          | ی بلوکات ثم                           | شكل (9-6) تقسيم الذاكرة إلـ   |  |  |  |  |  |  |  |

من شكل (9-7) نلاحظ أن وظيفة منتخب البلوكات هـــى اختيار واحـد مـن البلوكات على حسب الشفرة الموجودة على خطوط العناوين A13 و A14 و A15 و تتشيطه أي جعله جاهزا لاستقبال أو إرسال معلومات . لاحظ أيضا أن جميــع البلوكات متصلة بخطوط العناوين A0 إلى A12 لتحديد أي بايت داخــل البلـوك الذي تم اختياره سيتم التعامل معها . لاحظ أيضا اتصال كــل بلـوك بخطـوط التحكم MEMW و مسار البيانات D0 إلى D7 . مقارنة سريعة بيـن نظام تقسيم التليفونات العالمي في شكل (9-5) ونظام تقسيم الذاكرة إلى بلوكـات في شكل (9-7) نرى أن منتخب البلوكات في شكل (9-7) يلعب نفس الدور الذي يلعبه السنترال الدولي والذي يقوم بتوصيلك إلى دولة معينة على حســب الرقـم للداخل له ، فكذلك منتخب البلوكات على حسب الرقم أو الشفرة الموجودة علـــي

الخطوط A13 إلى A15 يقوم بتوصيل المعالج على واحد من هذه البلوكات . بعد قليل سنرى كيفية تقسيم البلوكات إلى شرائح كل منها يحتوى عددا معينا من البايتات والتى تتاظر عملية تقسيم الدول إلى مدن كما فى نظام التليفونات .



بمجرد تحديد عدد البلوكات من قبل المستخدم فإن المدى العنواني لكــل بلـوك يتحدد على حسب هذا العدد . المدى العنواني لأى بلوك يتحدد بتحديد عنـوان البداية وعنوان النهاية لكل بلوك ، لاحظ أن عنوان البداية لأى بلوك يبـدأ مـن حيث انتهى البلوك السابق له . شكل (9-8) يبين المدى العنواني للثمانية بلوكـلت الموجودة في شكل (9-7) وهو المثال الذي سنفترضه دائما فــي عمليـة بناء الذاكرة .

#### 9-3-5 بناء البلوكات من شرائح

نحن نعلم أن الذاكرة تكون في هيئة شرائح وكل شريحة لها سعة معينة ، فهناك مثلا شرائح سعتها 1 كيلو بايت وأخرى سعتها 2 كيلوبايت أو 512 بايت وأحيانا تجد 64 كيلوبايت على شريحة واحدة ، فما علاقة هذه الشرائح بالبلوكات أو وحدات البناء التى تكلمنا عنها سلفا؟ لما كان البلوك وحدة البناء في هيكل الذاكرة

الكلى فإن الشريحة ستكون وحدة البناء داخل البلوك ، أى أن البلوك يتكون من عدد من الشرائح وهذا العدد سيتوقف على سعة الشرائح المستخدمة ومن المفضل أن تكون جميع الشرائح داخل البلوك الواحد لها نفس السعة . فمثلا البلوك ذى الثمانية كيلوبايت الذى استخدمناه سلفا يمكن بناؤه من 4 شرائح كلم منها 2 كيلو أو من 8 شرائح كل منها 1 كيلو أو من شريحة واحسدة سعتها 8 كيلوبايت وهكذا .

| رقم    | A  | ر 15 | إلى | A0 | _ن | اويـ |   | و | _ ال | ŀ | نو |   | <b>h</b> | خ |   |   | العنوان |
|--------|----|------|-----|----|----|------|---|---|------|---|----|---|----------|---|---|---|---------|
| البلوك | 15 | 14   | 13  | 12 | 11 | 10   | 9 | 8 | 7    | 6 | 5  | 4 | 3        | 2 | 1 | 0 | استعشرى |
| 0      | 0  | 0    | 0   | 0  | 0  | 0    | 0 | 0 | 0    | 0 | 0  | 0 | 0        | 0 | 0 | 0 | 0000    |
|        | 0  | 0    | 0   | 1  | 1  | 1    | 1 | 1 | 1    | 1 | 1  | 1 | 1        | 1 | 1 | 1 | 1FFF    |
| 1      | 0  | 0    | 1   | 0  | 0  | 0    | 0 | 0 | 0    | 0 | 0  | 0 | 0        | 0 | 0 | 0 | 2000    |
|        | 0  | 0    | 1   | 1  | 1  | 1    | 1 | 1 | 1    | 1 | 1  | 1 | 1        | 1 | 1 | 1 | 3FFF    |
| 2      | 0  | 1    | 0   | 0  | 0  | 0    | 0 | 0 | 0    | 0 | 0  | 0 | 0        | 0 | 0 | 0 | 4000    |
|        | 0  | 1    | 0   | 1  | 1  | 1    | 1 | 1 | 1    | 1 | 1  | 1 | _1       | 1 | 1 | 1 | 5FFF    |
| 3      | 0  | 1    | 1   | 0  | 0  | 0    | 0 | 0 | 0    | 0 | 0  | 0 | 0        | 0 | 0 | 0 | 6000    |
|        | 0  | 1    | 1   | 1  | 1  | 1    | 1 | 1 | 1    | 1 | 1  | 1 | _1       | 1 | 1 | 1 | 7FFF    |
| 4      | 1  | 0    | 0   | 0  | 0  | 0    | 0 | 0 | 0    | 0 | 0  | 0 | 0        | 0 | 0 | 0 | 8000    |
|        | 1  | 0    | 0   | 1  | 1  | 1    | 1 | 1 | _ 1  | 1 | 1  | 1 | 1        | 1 | 1 | 1 | 9FFF    |
| 5      | 1  | 0    | 1   | 0  | 0  | 0    | 0 | 0 | 0    | 0 | 0  | 0 | 0        | 0 | 0 | 0 | A000    |
|        | 1  | 0    | 1   | 1_ | 1  | 1    | 1 | 1 | _ 1  | 1 | 1  | 1 | 1        | 1 | 1 | 1 | BFFF    |
| 6      | 1  | 1    | 0   | 0  | 0  | 0    | 0 | 0 | 0    | 0 | 0  | 0 | 0        | 0 | 0 | 0 | C000    |
|        | 1  | 1    | 0   | 1  | 1  | 1    | 1 | 1 | _1   | 1 | 1  | 1 | 1        | 1 | 1 | 1 | DFFF    |
| 7      | 1  | 1    | 1   | 0  | 0  | 0    | 0 | 0 | 0    | 0 | 0  | 0 | 0        | 0 | 0 | 0 | E000    |
| لِسِا  | 1  | 1    | 1   | 1  | 1  | 1    | 1 | 1 | 1    | 1 | 1  | 1 | 1        | 1 | 1 | 1 | FFFF    |

شكل (9-8) المدى العنواني لكل بلوك من الثمانية بلوكات في شكل (9-7)

السؤال الآن هو: كيف يتم توصيل هذه الشرائح داخل البلوك الواحد؟ إن طريقة توصيل الشرائح داخل البلوكات المحصول على توصيل الشرائح داخل البلوك هي نفسها طريقة توصيل البلوكات المحصول على هيكل الذاكرة . أي أن خطوط العناوين الداخلة للبلوك جزء منها سيستعمل لعنونة البايتات المختلفة داخل الشريحة والجزء الآخر سيستعمل الاختيار أو انتخاب الشرائح . إن عدد الخطوط في كل جزء من هذه الأجزاء سيتحدد على حسب سعة الشرائح المستخدمة ولنفرض البلوك ال 8 كيلوبايت كمثال . إذا استخدمنا شرائح سعة كل منها 2 كيلوبايت في بناء هذا البلوك فإن كل شريحة ستحتاج إلى المناخطا (A10 إلى A00) من ال 13 خطا الداخلة إلى البلوك ويتبقى خطان (A11)

و A12) يستخدمان في عملية اختيار الشرائح عن طريق منتخب آخر سنسميه منتخب اختيار الشرائح . لاحظ أنه باستخدام خطين يمكن اختيار واحدة من أربع شرائح حيث  $^2$  يساوى 4 . شكل ( $^9$ 9) عبارة عن مثال لبيان المدى العنوانيي لكل شريحة من شرائح البلوك الأول ، وحاول أنت كتابة المدى العنواني لشوائح واحد من البلوكات الأخرى . من شكل ( $^9$ 9) نلاحظ الآتى :

أول عنوان في أول شريحة في البلوك هو أول عنوان في البلوك ، فمثلا في شكل (9-9) العنوان الأول في أول شريحة في أول بلوك هو 0000 .

• آخر عنوان في آخر شريحة في البلوك هو آخر عنوان في البلوك ، فمثلا في شكل (9-9) آخر عنوان في آخر شريحة في البلوك الأول هو 1FFF وهو آخر عنوان في أول بلوك كما في شكل (9-8) .

• خطوط اختيار البلوك A13 و A14 و A15 كانت أصفارا دائما لأنا في اللوك الأول الذي مداه العنواني 0000 إلى 1FFF .

خطوط اختيار الشريحة ثابتة لا تتغير طول مدى الشريحة ، فالشريحة الأولى
 خطوط اختيارها كانت 00 والشريحة الثانية خطوط اختيارها كانت 01 وهكذا .

• أول عنوان في الشريحة نحصل عليه بأن نضع جميع خطوط اختيار البايت داخل الشريحة (A10 إلى A10) تساوى أصفارا ، وآخر عنوان في الشريحة نحصل عليه بأن نضع هذه الخطوط تساوى وحايد .

|    |    |    | ) A0 |    |                                              |     |          |   |   |   |   |   |   |   |   |   | المدى    | رقم     |
|----|----|----|------|----|----------------------------------------------|-----|----------|---|---|---|---|---|---|---|---|---|----------|---------|
| 15 | 14 | 13 | 12   | 11 | ! 1                                          | 0 9 | )        | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | العنواني | الشريحة |
| 0  | 0  | 0  | 0    | 0  | . (                                          | ) ( | )        | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0000     | 0       |
| 0  | 0  | 0  | 0    | 0  | <u>!                                    </u> |     | l .      | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 07FF     |         |
| 0  | 0  | 0  | 0    | 1  | ! (                                          | ) ( | )        | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0800     | 1       |
| 0  | 0  | 0  | 0    | 1  | <u>! ]</u>                                   |     | l_       | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0FFF     |         |
| 0  | 0  | 0  | 1    | 0  | F (                                          | ) ( | )        | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1000     | 2       |
| 0  | 0  | 0  | 1    | 0  | 1                                            |     | l        | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 17FF     |         |
| 0  | 0  | 0  | 1    | 1  | (                                            | ) ( | )        | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1800     | 3       |
| 0  | 0  | 0  | 1    | 1  | <u>i 1</u>                                   |     | <u> </u> | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1FFF     |         |

شكل (9-9) المدى العنواني لكل شريحة داخل البلوك الأول

شكل (9-10) يبين التركيب الداخلى لأحد البلوكات الثمانية المبينة في شكل (9-7) حيث يتكون هذا البلوك من أربع شرائح كل منها 2 كيلوبايت ولذلك فإن كل شريحة من هذه الشرائح لها 11 خطا للعناوين متصلة بالخطوط A0 إلى عناوين المعالج . كذلك فإن كل شريحة كما نرى لابد وأن تكون متصلة بمسار العناوين D0 إلى D7 . إن منتخب الشرائح الموجرود في

شكل (9-10) وبناء على الشفرة الموجودة على دخليه All و All سيكون واحد فقط من خروجه فعالا وباقى الخروج خاملة مما سيجعل شريحة الذاكرة المتصلة بهذا الخرج هى فقط الفعالة وأما باقى الشرائح فستكون خاملة ، وعلى ذلك فإن هذه الشريحة وبناء على الشفرة الموجودة على الخطوط Al إلى Al0 سيتكون إيتاتها جاهزة للتعامل مع المعالج إما للكتابة أو للقراءة على حسب حالفلا الخطين ، MEMW و MEMW . لاحظ أن منتخب الشرائح في شكل (9-10) لن يكون فعالا إلا إذا جاءت له إشارة أو نبضة من منتخب البلوكات في شكل (9-7) تخبره أن هذا البلوك قد اختير للتعامل مع المعالج وبذلك يصبح منتخب الشرائح فعالا .



شكل (9-11) يبين نظام ذاكرة مكون من 8 بلوكات وكل بلوك مكون من 4 شرائح وكل شريحة مكونة من 2 كيلوبايت فهل نستطيع الآن مقارنة هذا الشكل بشكل (9-5) الذي يبين رسما توضيحيا لنظام تليفونات عالمي؟ إن منتخب البلوكات يناظر السنترال الدولة التي تحم المبلوكات يناظر البايت داخل الشريحة يناظر رقم أي تليفون داخل الدولة التحي

تم اختيارها بإهمال سنترالات المدن . شكل (9-12) يبين رسما توضيحيا لنظام الثمانية بلوكات الذى نفترضه فى شرحنا وذلك حتى يتمكن القارئ من إلقاء نظرة شاملة على نظام الذاكرة بأكمله . لاحظ أن البلوكات ما بين الأول والأخير فسى هذا الشكل ما هى إلا تكرار مثل البلوك رقم صفر والبلوك رقم 7 .



إن نظام بناء الذاكرة باستخدام البلوكات الذي تم شرحه حتى الآن ليس هو النظلم الوحيد الذي يجب أن يؤخذ به في عملية بناء أي نظام ذاكرة ، ولكن من مميزات هذا النظام أنه يعتبر عاما يمكن تعديله ليناسب أي غرض . فمن الممكن مثلا أن يبنى النظام بحيث يكون كل بلوك على كرت منفصل وتكون الذاكرة في هذه الحالة عبارة عن مجموعة من الكروت التي يستعمل منها ما يلزم للحاجة فقط أيضا يمكن استخدام نوعى الذاكرة (إما RAM أو ROM) على أي واحد من هذه الكروت ، فقط يجب الحرص عند توصيل خطوط التحكم ، MEMW و MEMW. خلاصة القول أن نظام الكروت هذا يمكن أن يحور أو يعدل ليتناسب مع أي تصميم مطلوب . شكل (9-13) يبين الدائرة الكاملة لأحد البلوكات السابقة وقد

استخدمنا معه شريحة الذاكرة رقم 6116 التي تحتوى على 2 كيلوبايت RAM استاتيكية . هذه الشريحة متوافقة تماما من حيث وظيفة الأطراف مع الشريحة رقم 2716 التي تحتوى على 2 كيلوبايت EPROM بحيث أنه يمكن استخدام أي واحدة من الشريحتين مكان الأخرى .





إن جميع محتويات هذا الفصل ليست خاصة بمعالج بعينة دون الآخر ولكنها تناسب أى واحد من المعالجات التى هى تحت الدراسة فى هذا الكتاب ، ولقد رأينا فى الفصل السابق كيف حصلنا على المسارات الثلاثة لكل معالج فى الصورة المناسبة لعملية المواجهة ولذلك فإننا نلاحظ أن الشرح لم يكن موجها إلى أى

معالج بعينة ولكن كل ما قيل في هذا الفصل يمكن تطبيقه مصع أى واحد من المعالجات تحت الدراسة في هذا الكتاب .

#### 9-4 تمارين

- 1. مطلوب توصيل شريحة ذاكرة EPROM سعتها 2 كيلوبايت على معالج ، ما هي أبسط الطرق لتوصيل هذه الشريحة مع العلم أنها ستكون شريحة الذاكرة الوحيدة ؟
- 2. مطلوب توصيل شريحتى ذاكرة EPROM و RAM سعة كل منهما 2 كيلوبايت على المعالج ، ما هى أبسط الطرق لذلك مع العلم أنهما شرائح الذاكرة الوحيدة الموصلة على المعالج ؟
- 3. لديك العديد من شرائح الذاكرة RAM و EPROM التى سعة كل منها 1 كيلوبايت ، ارسم نظام ذاكرة متكامل مكون من بلوكات واقسترح أنست عدد البلوكات الذى ستستعمله ؟ اكتب عنوان البداية وعنوان النهاية لكل بلوك وكل شريحة ؟
- 4. ارسم نظام ذاكرة متكامل مكون من 16 بلوك مستخدما شرائح كـــل منــها 4
   كيلوبايت ؟ اكتب عنوان البداية وعنوان النهاية لكل بلوك وكل شريحة؟
- أعد السؤال الرابع إذا كانت الشرائح المستخدمة سعة كل منها 4 كيلوبايت أيضا ولكن مسار البيانات لكل منها 4 بتات بدلا من 8 ؟

# الفصل العاشر

الإدخال والإخراج Input and Output

#### 1-10 مقدمة

بالإضافة إلى وحدة التحكم المركزى أى ال cpu والذاكرة بأنواعها فإن الكومبيوتر ودوائر التحكم التى تستخدم المعالجات أو الكومبيوتر لابد وأن تحتوى على وحدات لإدخال وإخراج المعلومات والتي من شأنها تسهيل عملية تبادل المعلومات بين الأجهزة المحيطة والمعالج الأجهزة المحيطة مثل الطابعات والشاشات والمحولات من رقمي إلى تماثلي والعكس وأى أجهزة خارجية يقوم المعالج بالتحكم فيها أو التعامل معها قد رأينا في الفصل السابق كيفية توصيل المعالج على شرائح الذاكرة سواء كانت RAM أو ROM وسنقوم في هذا الفصل بعرض كيفية بناء وتوصيل المعالج على بوابات الإخراج والإدخال ونؤكد هنا أيضا أن محتويات هذا الفصل ليست خاصة بمعالج بعينه دون الأخراج واكنها وبالذات بعد أن رأينا في الفصل الثامن كيفية الحصول على المسارات المختلفة وبالذات وتهيئتها . لكي ننمي الإحساس لدينا بأهمية الحاجة إلى بوابات المختلفة المعالجات وتهيئتها . لكي ننمي الإحساس لدينا بأهمية الحاجة إلى والآتي :

إن وجود شريحة المعالج كوحدة عمليات مركزية داخل الميكروكومبيوتر ليست الوظيفة الوحيدة لمثل هذا النوع من الشرائح. هناك مجال واسع من الاستخدامات والتطبيقات لهذه الشرائح وهو استخدامها كعنصر أساسى من عناصر أنظمة التحكم، فمثلا التحكم في أي عملية كيماوية يمكن الشرائح المعالجات أن تلعب دورا مهما فيه، التحكم في عمليات خلط البنزين والهواء داخل السيارة مجال من المجالات التي استخدمت هذه الشرائح. إن هذه مجرد أمثلة بسيطة ولكن مجمل القول هو أن شرائح المعالجات تلعب في الوقت الحللي دورا مهما جدا في معظم العمليات الصناعية بل وفي الكثير من الأجهزة والآلات التي نستخدمها في حياتنا اليومية.

شكل (1-10) يبين نظاما بسيطا لتقطير المياه وقد استخدم الكومبيوتر كعنصر أساسى من عناصر التحكم فيه . إن المياه المطلوب تقطيرها يتم تسخينها باستخدام سخان إلى أن يتحول الماء إلى بخار في أعلى التنك حيث يتم سحب هذا البخار في أنبوبة يمين أعلى التنك حيث يتم تكثيف البخار إلى ميساه نقية . إن السخان يجب أن يتوقف عندما تصل درجة حرارة المياه إلى درجة قصوى ويعاد تشغيله إذا وصلت الحرارة إلى حد أدنى ، ويتم ذلك عن طريق ميكروكومبيوتر مخزن فيه كل من الدرجتين العظمى والصغرى ويقوم الكومبيوتر بقراءة درجة حرارة التنك من خرج مبدل (Transducer) لدرجة الحرارة على فترات زمنية محددة ويقارنها بالدرجتين العظمى والصغرى ويقرر إذا كان سيشغل السخان أم محددة ويقارنها بالدرجتين العظمى والصغرى ويقرر إذا كان سيشغل السخان أم يوقفه . بنفس الطريقة يقرأ الكومبيوتر مبدل مستوى المياه في التسك ويقارنها يوقفه . بنفس الطريقة يقرأ الكومبيوتر مبدل مستوى المياه في التسك ويقارنها

بأعلى وأقل قيمة لمستوى المياه حيث هاتان القيمتان مخزنتان في الذاكرة ويقرر بناء على ذلك إذا كان سيتم فتح أو غلق صمام إدخال المياه . إن ضغط بخار الماء الموجود في أعلى التنك من الممكن أن يزيد إلى درجة الخطورة ، لذلك فقد تم وضع مبدل للضغط في هذا الجزء من النتك حيث يقوم الميكروكومبيوتر من وقت لأخر بقراءة خرج هذا المبدل ومقارنتها بقيمتين عظمى وصغرى وعلى ضوء هذه المقارنة يقرر إذا كان سيترك صمام الأمان مغلقا أم يفتحه لفترة محددة من الزمن لثقليل الضغط في أعلى التنك ومستوى المياه فيه وكذلك المستوى الضغط في أعلاه عند القيمة المثلى لكل منها . إن عدد المتغيرات التي يتم التحكم فيها بواسطة الميكروكومبيوتر من الممكن أن يكون أكثر من ذلك برء بيتم التحكم فيها بواسطة الميكروكومبيوتر من الممكن أن يكون أكثر من ذلك جزء بسيط من عمليات تحكم أخرى يقوم الكومبيوتر بالتحكم فيها داخل أحدد المصانع .



إن أهم ما يجب ملاحظته في هذا المثال الموجود في شكل (10-1) هو عمليسة الربط بين عالم الرقميات المتمثل في الكومبيوتر حيث تكون جميسع الإشسارات الموجودة رقمية فقط (Digital) ، وعالم التناظريات أو التماثليات المتمثل في تنك المياه وإشارات التحكم فيه حيث تكون جميع هذه الإشارات تماثليسة (Analog) . فمثلا لكي يعمل السخان لابد من توصيله بجهد عال (220 فولت مثلا) ، وكذلك فمثلا لكي تفتح أو تغلق أيا من الصمامات لابد من استخدام هذا الجسهد العسالي ، إذن كيف يتم هذا الربط ؟ أو بمعني آخر كيف تحول الإشارات الرقمية الخارجة مسن الكومبيوتر إلى إشارات تماثلية أو جهد عال يتم به تشغيل السخان مثلا؟ وكيسف يتم أخذ الإشارة الخارجة من أي من المبدلات وهي إشارة تماثلية غالبا ما تكون طعيفة ، كيف يتم تحويلها إلى إشارة رقمية يمكن الكومبيوتر أن يتعامل معها ؟ جميع هذه الأسئلة وغيرها سيتم الإجابة عنها في هذا الفصل والفصول القادسة . وإخراج المعلومات إلى ومن الكومبيوتر بافتراض أن هذه المعلومات موجودة في الصورة الرقمية .

### 2-10 طرق إرسال واستقبال المعلومات الرقمية

إن المعلومات التي يتم إدخالها أو إخراجها من أو إلى الكومبيوتر تكون إما في صورة تتابعيه Parallel data وفي صورة متوازية اليه بالضرورة . في الصورتين له مميزاته والاستخدامات الخاصة التي تحتاج إليه بالضرورة . في الطريقة التتابعية يتم إرسال المعلومات من وإلى الأجهزة الخارجية علي خط واحد فقط و لا يرسل على هذا الخط إلا بت bit واحدة فقط في نفس وحدة الزمن وهي ال Clock ، بحيث أنه لكى يتم إرسال معلومة من ثمانية بتات مثلا فإننا نحتاج إلى زمن مقداره ثماني نبضات تزامن لكي نرسل هذه المعلومة . أما في الطريقة المتوازية فإن المعلومات يتم إرسالها من وإلى الكومبيوتر على أكثر من خط واحد ، وعادة ما يكون عدد هذه الخطوط يساوي عدد الخطوط في مسار البيانات للكومبيوتر الذي يتم التعامل معه وفي هذه الحالة فإننا لكي نرسل معلومة من ثماني بتات مثلا سنحتاج إلى ثمانية خطوط متوازية بحيث ترسل كسل بت على خط منفصل من هذه الخطوط وبالطبع فإنه في هذه الحالة سترسل جميع هذه البتات في خلال نبضة تزامن Clock واحدة فقط ، لذلك فإن هذه الطريقة أسرع بكثير في إرسال المعلومات من الطريقة التتابعية السابقة . شكل (2-10) يبين رسما توضيحيا لطرق إرسال المعلومات بالطريقتين التتابعية والمتوازية .



إن عملية إدخال أو إخراج معلومة من أو إلى الكومبيوتر تتكون من جزأين، الجزء الأول منها هو برنامج Software يقوم الكومبيوتر بتنفيذه ، والجزء الثاني هو دائرة Hardware يتم بناؤها لكى تقوم بدور الوسيط بين الكومبيوتر والأجهزة الخارجية . لكتابة برنامج يقوم بإدخال أو إخراج معلومات من أو إلى الكومبيوتو فإن هناك أيضا طريقتين : الطريقة الأولى يتم فيها استخدام الأمر IN لإدخال المعلومة والأمر OUT لإخراجها والتي تسمى بطريقة خريطة الإدخال والإخراج للإدخال والإخراج المحلومة والأمر To Utput mapped المتخدام خريطة ذاكرة الكومبيوتر ولذلك تسمى هذه الطريقة الثانية وفيها يتم استخدام خريطة ذاكرة الكومبيوتر ولذلك تسمى هذه الطريقة الثانية الذاكرة الكومبيوتر ولذلك تسمى هذه الطريقة STA من بايتات الذاكرة ولذلك يمكن مع هذه الطريقة استخدام أوامر المعالج العادية مثل الأوامر STA, MOV, وذلك على العكس من الطريقة الأولى والتي لا يستخدم معها إلا

الأمرين IN, OUT فقط . سيأتي شرح هذه الطريقة فيما بعد وكذلك سنرى أن الدائرة أو ال Hardware الذي يستخدم مع كل من الطريقتين لا يختلف كثيرا .

# 3-10 الطريقة الأولى من طرق الإدخال والإخراج باستخدام الأمرين OUT, IN

هذه الطريقة من طرق الإدخال والإخراج لا تستعمل مع المعالج MC6800 على الإطلاق حيث لا تحتوى قائمة أوامر هذا المعالج على الأمريل IN و OUT و لكن تستخدم معه طريقة خرائط الذاكرة التي سنشرحها في الجزء القادم إن شاء الله .

كما نعلم فإن الأمرين OUT, IN يتكون كل منهما من 2 بايت ، البايت الأولى هي شفرة الأمر ، أما البايت الثانية فتحتوى على رقم بوابة الإخراج أو الإدخال التي سيتم التعامل معها . كما نعلم أيضا فإن البايت تتكون من ثماني بتات ولذلك فإنه يمكن تشفير عدد من بوابات الإدخال أو بوابات الإخراج يصل إلى 256 بوابة (28) . عندما يقوم المعالج بتنفيذ الأمر OUT أو الأمر IN فإن رقم البوابة يتم وضعه على الثمانية خطوط الأولى من مسار العناوين ، فمثلا عند تنفيذ الأمر OUT 05 حيث 05 هي رقم أو عنوان بوابة الإخراج فإن المعالج يضع الرقم 05 على مسار العناوين كالتالي :

A7 A6 A5 A4 A3 A2 A1 A0 0 0 0 0 1 0 1

أما محتويات مسجل التراكم وهي المعلومة المطلوب إخراجها فيتم وضعها على مسار البيانات تمهيدا لالتقاطها بواسطة بوابة الإخراج في اللحظة المناسبة . كذلك الحال بالنسبة للأمر IN فمثلا عند تنفيذ الأمر IN فيان رقم بوابة الإدخال وهو JF يقوم المعالج بوضعه على مسار العناوين كالتالى :

A7 A6 A5 A4 A3 A2 A1 A0

أما المعلومة المراد إدخالها فتتقل من مسار البيانات الذي يكون متصلاً ببوابية الإدخال في هذه اللحظة إلى مسجل التراكم ، ويجب التأكيد هنا على أنه في أثناء نتفيذ الأمر OUT فإن الخط IOW من مسار التحكم يكون فعيالا أي صفرا ، وكذلك في أثناء تتفيذ الأمر IN فإن الخط IOW من مسار التحكم يكون فعيالا ويساوى أيضا صفرا . لذلك فإن الخطين IOW و IOW مهمان جدا في بناء كه من دائرتي الإدخال والإخراج كما سنرى ، ولقد رأينا في فصل سابق كيفية الحصول على هذه الخطوط مع كل معالج نقوم بدراسته في هذا الكتاب .

الشكلان (10–3) و (10–4) يبينان الترامن الموجود على جميع خطوط التحكم التي تتأثر بالأمرين IN و OUT في حالمة المعالج 8085 . هذان الشكلان يستحقان التأمل والتدقيق من قبل أي قارئ حيث أنه يمكن منهما ملاحظة وفهم الكثير من طريقة تنفيذ المعالج لأي أمر والترامن الذي يحدث بين إشارات التحكم المختلفة . شكلا (10–5) و (10–6) يبينان الترامن الموجود على جميم خطوط التحكم التي نتأثر بالأمرين IN و OUT في حالة المعالج 280 و هذان الشكلان يستحقان التدقيق أيضا من جميع القراء لملاحظة مدى التشابه بين معظم هذه الإشارات .

#### 1-3-10 دائرة بوابة الإخراج Output port

شكل (10-7) يبين رسما تخطيطياً لبوابة إخراج . كما رأينا فإن كلا من الشريحة Intell 8085 و 280 يمكنها التعامل مع 256 بوآبة إخراج يمكن ترقيمــها مـن البوابة رقم صفر إلى البوابة رقم 255 . لذلك فقد خصصت المفاتيح S1 إلى S8 الاختيار رقم اللبوابة ووضعه في الصورة الثنائية باستخدام هذه المفاتيح . عند تتفيذ الأمر OUT فإن رقم البوابة كما ذكرنا من قبل يظهر على الثمانية خطوط الأولى من مسار العناوين A0 إلى A7 . هنا تكون مهمة مقارن العناوينAddress Comparator حيث يقارن الرقم الموجود علي مسار العناوين مع الرقم الموضوع بالمفاتيح ، فإذا تطابق الرقمان يقوم مقارن العناوين بإعطاء إشارة. خرج تدل على ذلك ، وإذا لم يتطابقا يظل خرجه خاملا دون تغيير . تستخدم إشارة الخرج القادمة من مقارن العناوين لتشغيل ماسك الخرج Output latch ذي الثمانية بتات كما هو مبين بشكل (10-7) . لاحظ أن دخل مآسك الخرج متصل بمسار البيانات والذي توضع عليه المعلومة المراد إخراجها في أثناء تتفيذ الأمر OUT ، وفي حالة وجود إشارة الخرج القادمة من مقارن العناوين يقوم ماسك الخرج بنقل المعلومة الموجودة على دخله إلى خرجه حيث يمكن إظهارها علي شاشة أو مظهرات أو الاستفادة منها في أي غرض من الأغراض. الذي يهمنا الآن هو أن المعلومة الموجودة داخل المعالج وبالتحديد في مسجل الستراكم تسم إخراجها على ماسك حيث من هنا تبدأ الاستفادة بها . لاحظ أيضا أن الخط IOW تم استخدامه كخط تشغيل مع مقارن العناوين بحيث لا يعمل مقارن العناوين إلا إذا كان هذا الخط فعالا أي يساوي صفرا.











شكل (10-8) يبين الدائرة الكاملة لبوابة الإخراج . الشريحتان 7485 كل منهما عبارة عن مقارن ذى أربع بتات حيث يكون خرج الشريحة على الطرف 6 يساوى High إذا كانت كل بت من الدخل A تساوى نظيرتها من الدخل B وكان دخل الشريحة على الطرف 3 يساوى High أيضا . لذلك فإن الإشارة TOW تسم لا المناه الشريحة على الطرف 3 للشريحة الأولى وتم توصيل خرج هذه الشريحة (الطوف ألى الشريحة الأولى وتم توصيل خرج هذه الشريحة (الطوف ألى بنلك تعمل الشريحة الشريحة الثانية (الطرف ألى بنلك تعمل الشريحة الشريحة الشريحة الثانية يستخدم كنبضات تزامن Clock الشريحة الثانية . هذا الخرج من الشريحة الثانية يستخدم كنبضات تزامن Clock الشريحة الماسك وذلك بعد عكسه . الشريحة 74273 عبارة عن ماسك ذى ثمانى بتات وعند عبور الستزامن (الطرف 11) من Low إلى High تنتقل الإشارة الموجودة على الدخل إلى الخرج مباشرة . الطرف 1 للشريحة 27427 خاص بالتصفير Clear ألى المناك يصبح كل خرج الشريحة يساوى صفر ولذلك فقد عندما يكون هذا الطرف على ال RESET لصمان أن يكون خرج الماسك يساوى صفرا عند بداية التشغيل . لاحظ أن الاستفادة من الخرج تبدأ من هنا حيث يمكن توصيل خرج الماسك على محول رقمي/تماثلى أو على مظهر وذلك على حسب توصيل خرج الماسك على محول رقمي/تماثلى أو على مظهر وذلك على حسب توصيل خرج الماسك على محول رقمي/تماثلى أو على مظهر وذلك على حسب

التطبيق الذي ستستخدم فيه هذه البوابة . لقد كان من الممكن استخدام منتخب decoder بدلا من مقارن العناوين ولكن ميزة استخدام المقارن أنه يمكن تغيير رقم أو عنوان البوابة على حسب الطلب باستخدام المفاتيح 80 إلى 87 .



# 2-3-10 دائرة بوابة الادخال Input port

شكل (10-9) يبين رسما تخطيطيا لبوابة إدخال . كما عامنا فإن كلا من الشريحة 108 Intell 8085 يمكنهما التعامل مع 256 بوابة إدخال والتي يمكن ترقيمها أو عنونتها من البوابة رقم صفر حتى البوابة ووضعه في الصورة الثنائية خصصت المفاتيح S1 حتى S8 لاختيار رقم البوابة ووضعه في الصورة الثنائية باستخدام هذه المفاتيح . عند تتفيذ الأمر IN فإن رقم البوابة كما ذكرنا من قبل باستخدام هذه المفاتيح . عند تتفيذ الأمر العناوين رقم البوابة كما ذكرنا من قبل يظهر على الثمانية خطوط الأولى من مسار العناوين ملا إلى A7 ، اذلك فإن الرقم الموجود على مسار العناوين مسع الرقم الموضوع بالمفاتيح ، فإذا تطابق الرقم الموجود على مسار العناوين من يتطابقا يظل الخرج خاملا أي غير فعال . تستخدم إشارة الخرج القادمة من مقارن العناوين لتشغيل عازل Buffer ذي ثماني بتات الذي رقمه 74244 ، انظر الى محتويات هذه الشريحة في الفصل الثامن . إن دخل العازل متصل بالمصدر

الذى تأتى منه المعلومة المراد إدخالها إلى المعالج ، لاحظ أنه عندمها يكون مقارن العناوين خاملا أى أن خرجه غير فعال فإن العازل أيضا سيكون غير فعال وسيكون خرجه عبارة عن مقاومة عالية حتى لا يسبب تحميلا لمسار البيانات Short circuit فى حالة اتصال مسار البيانات بأى جهاز آخر ولقد عرفنا ذلك فى دراستنا لبوابات المنطق الثلاثى . لقد تم استخدام الخط IOR كخط تشغيل مع مقارن العناوين بحيث لا يعمل مقارن العناوين إلا إذا كان هذا الخط فعالا أى يساوى صفرا .



شكل (10-10) يبين الدائرة الكاملة لبوابة إدخال . لاحظ مدى التناظر بين هذه الدائرة ودائرة بوابة الإخراج ، الفرق الأساسى هو استخدام ماسك الخرج فك حالة بوابة الإخراج لمسك المعلومة التي سيتم إخراجها أمنا في حالية بوابية الإدخال فيستخدم عازل Buffer لعزل مسار البيانات عن المصدر الذي تدخل منه المعلومة .



# 4-10 الطريقة الثانية من طرق الإخراج والإدخال باستخدام خريطة الذاكرة Memory mapped I/O

إن خريطة الذاكرة لأى حاسب هي عبارة عن رسم تخطيطي يبين فيم تستخدم كل بايت من بايتات الذاكرة ابتداء من أول بايت إلى آخر بايت في الذاكرة . فمثلا خريطة الذاكرة الخاصة بالميكروكومبيوتر الذي نستخدمه مع أمثلة هذا الكتاب والموضحة في شكل (10-11) فيها البايتات ابتداء من 0000 إلى 1FFF مشغولة بذاكرة قراءة فقط PROM, فيها البايتات ابتداء من المنظام التشيغيل الخاص بهذا الميكروكومبيوتر فيشغل الذاكرة ابتداء من البايت FC00 إلى FFFF. انظر إلى شكل (10-11) لتتعرف فيما تستخدم باقى الذاكرة . يمكن كما سينرى استخدام طريقة خرائط الذاكرة للإبخال والإخراج مع أي معالج ولكن مع المعالج المعالج ليس لديه أوامر إدخال وإخراج مثل أبناء جيله 8085 و Z80.

فى هذه الطريقة من طرق الإدخال والإخراج تعامل بوابة الإدخال أو الإخـــراج كما لو كانت بايت من بايتات الذاكرة ولذلك فإن جميع أوامر المعـــالج الخاصــة

بالتعامل مع الذاكرة يمكن استخدامها في هذه الحالة . لكي نستخدم بايت من بايتات الذاكرة في هذا الغرض فإنه يجب التأكد من أن هذه البايت غير مستخدمة في أي غرض من أغراض التخزين الأخرى ويمكن معرفة ذلك طبعا بعد النظو في خريطة الذاكرة وانتقاء البايت المناسبة لذلك بحرص شديد . بالنظر في خريطة الذاكرة فإننا سنبتعد عن مساحات الذاكرة المستخدمة لنظام التشييل والمستخدمة كذاكرة تزين قراءة فقط وكذلك المستخدمة كذاكرة تخزين BFFF مشلا وسوف وستخدم أي مكانين في هذه المساحة المحددة بالعنوانين A000 إلى BFFF مثلا وسوف نستخدم أي مكانين في هذه المساحة أحدهما كبوابة إدخال والآخر كبوابة إخراج . إنه في هذا المجال يجب أن نذكر جيدا أنه عندما تقوم شريحة المعالج بتنفيذ أي أمر من الأوامر التي تتعامل مع الذاكرة فإن عنوان المكان الذي سيتم التعامل معه يوضع على مسار العناوين (16 خطا) وفي هذه الحالة فإن خطيي التحكم من الذاكرة أو الكتابة فيها على حسب ما سيكون أي من الخطين فعالا . لذلك من هذين الخطين سيلعبان دورا مهما في عملية التشفير الخاصة ببوابة فإن كلا من هذين الخطين سيلعبان دورا مهما في عملية التشفير الخاصة ببوابة فإن كلا من هذين الخطين سيلعبان دورا مهما في عملية التشفير الخاصة ببوابة فإن كلا من هذين الخطين سيلعبان دورا مهما في عملية التشفير الخاصة ببوابة فإن كلا أو بوابة الإخراج كما سنري فيما يلي :



# 10-4-10 دائرة بوابة إخراج باستخدام خريطة الذاكرة

افترض مثلا أنه بالنظر في خريطة الذاكرة الخاصة بـــالميكروكومبيوتر الــذي نستخدمه وجدنا أن مساحة الذاكرة التي تبدأ من المكان A000 إلى المكان المكان عير مستخدمة لأى غرض من أغراض التخزين ، لذلك فإننا سنســتخدم أحــد أماكن هذه المساحة كبوابة إخراج وليكن مثلا المكان رقم AFFF . شــكل (10) يبين دائرة مقترحــة لهذه البـوابة . عند تنفيذ الأمرين :

MVI A,05 STA AFFF



بواسطة المعالج فإن الأمر الأول سيضع الرقم 05 في مسجل الستراكم والأمسر الثاني سيتسبب في وضع العنوان AFFF على مسار العناوين (A0 إلى  $\overline{\text{MEMW}}$  فعالا ، ثم يضع محتويات مسجل التراكم على مسار البيانات ، لذلك فإنه بالنظر إلى شكل (10-10) فإن خرج فاكك الشفرة سيكون فعالا مما يسبب نبضة تزامن Clock pulse الماسك (الشريحة 74273) الذي يقوم بإخراج محتويات مسار البيانات على الخرج وذلك هو المطلوب من أي بوابسة أو إخراج حيث يمكن في هذه الحالة الاستفادة من الخرج أو إظهاره على شاشة أو مظهر من أي نوع كما فعلنا مع بوابة الإخراج سابقا . لاحظ أنه يمكن استخدام مقارن للعناوين كما في الأجزاء السابقة بدلا من فاكك الشفرة أو منتقى العنسوان AFFF الموجود في شكل (10-10) .

# 2-4-10 دائرة بوابة ادخال باستخدام خريطة الذاكرة

افترض أننا سنستخدم المكان BFFF من أماكن الذاكرة كبوابة إدخـــال . شــكل 13-10 يبين الدائرة المقترحة لذلك . عندما تقوم شريحة المعالج بتنفيذ الأمر: LDA BFFF

فإن العنوان BFFF سيوضع على مسار العناوين (A0 إلى A15) وسيكون الخط MEMR في هذه المرة فعالا ، اذلك فإنه في هذه الحالة سيكون خرج فاكك الشفرة أو المنتقى فعالا كما في شكل (10-13) مما سيسبب نبضة تزامن اشريحة العازل Buffer والتي بسببها يقوم العازل بنقل المعلومة الموجودة على دخله وهي المعلومة القادمة من الخارج ويضعها على مسار البيانات حيث يقوم المعالج بنقل هذه المعلومة إلى مسجل التراكم . لاحظ أن العازل Buffer لابد وأن يكون مسن النوع ثلاثي المنطق .

بالنظر إلى دوائر الإدخال والإخراج باستخدام خريطة الذاكرة وباستخدام الأمرين IN, OUT نلحظ مدى التناظر بينهما ، ففى أى من الطريقتين لابد وأن يكون هناك فاكك شفرة أو منتقى لرقم البوابة ، الاختلاف هو أنسه فى حالة استخدام خريطة الذاكرة فإننا نشفر مسار العناوين بالكامل (16 خطا) وذلك فى حالة التشفير الكامل ، أما فى حالة استخدام الأمرين IN, OUT فإنا نشفر الثمانية خطوط الأولى فقط من مسار العناوين وذلك أيضا فى حالة التشفير الكامل . هناك أيضا فرق أساسى وهو أننا مع طريقة خريطة الذاكرة نستخدم الكامل . هناك أيضا فرق أساسى وهو أننا مع طريقة الأخرى فإننا نستخدم الخطين خطى التحكم MEMR و MEMW أما مع الطريقة الأخرى فإننا نستخدم الخطين خطى التحكم IOW ويما عدا ذلك فإن الماسك Latch أو العازل Buffer يستخدمان فى كل من الطريقتين إما لمسك معلومة الخرج فى حالة بوابة الإخراج أو لعول مصدر المعلومة عن مسار البيانات فى حالة بوابة الإدراج أو لعول

لقد راعينا في جميع الدوائر السابقة استخدام عملية التشفير الكاملة للبوابات في الحالتين سواء باستخدام الأمرين IN, OUT أو باستخدام خرائط الذاكرة، ونعني بالتشفير الكامل أن جميع خطوط العناوين (الثمانية أو الستة عشر علي حسب الطريقة المستخدمة) تستخدم في عملية التشفير، فمع خرائط الذاكرة مثلا استخدمنا جميع خطوط مسار العناوين (A0 إلى A15) وفي حالة الأمرين, IN, استخدمنا ال 8 خطوط الأولى من مسار العناوين. في الحقيقة فإن دائرة التشفير من الممكن أن تكون أبسط من الدوائر السابقة بكثير لو أننا استخدمنا عددا أقل من خطوط العناوين.



شكل (10–10) يبين عملية تشفير لبوابة إخراج باستعمال الأمر OUT وباستخدام خط واحد من مسار العناوين وهو الخط A0. المشكلة مع مثل هذه البوابة هي أن

أى رقم أو عنوان تكون فيه البت A0 تساوى واحدا سيتسبب في تشغيلها . فمثــلا جميع الأوامر التالية تصلح لتشغيل هذه البوابة :

OUT 01

OUT 03

**OUT FF** 

وهكذا فإن أى رقم يبدأ بواحد فى البت AO سيشغل هذه البوابة . فى الحقيقة فإن بناء مثل هذه البوابات الناقصة التشفير ليس به أى عيب طالما أنه ليست هناك بوابات تحمل هذه الأرقام المتكررة ويجب أن يراعى ذلك فى عملية التصميم . نفس الكلام يمكن تطبيقه على عمليات تشفير البوابات التسبى تستخدم خرائط الذاكرة .



# 10-10 البوابات القابلة للبرمجة Programmable Peripheral Interface, PPI

الشريحة Intell 8255A هي إحدى الشرائح المهمة التي تصاحب دائما وفي الكثير من التطبيقات شرائح المعالج ، إن هذه الشريحة تسمى Programmable واختصارا تكتب PPI . تحتوى هذه الشريحة كما سارى على ثلاث بوابات كل منها ثماني بتات وهذه البوابات قابلة للبرمجة بمعنى أناه من داخل البرنامج يمكن جعل أي واحدة من هذه البوابات بوابة إدخال أو إخراج عن طريق أمرين فقط من أو امر لغة الأسمبلي وهذه تعتبر من المميزات العظيمة

لهذه الشريحة حيث أنها توفر الكثير من الدوائر التي كانت تستخدم في عملية تشفير البوابات ، فلك أن تتخيل أن أمامك ثلاث بوابات لك الحرية في أن تجعل أي واحدة منهم إدخال أو إخراج كما تشاء ومن داخل البرنامج ودون اللجوء إلى أي تغيرات أو تعديلات في الدوائر التي تم بناؤها .

# 1-5-10 تركيب الشريحة 8255A

هذه الشريحة يمكن تقسيمها إلى جزأين رئيسيين ، جزء يواجه شريحة المعبالج والجزء الآخر يواجه العالم الخارجي . شكل (10-15) يبين رسما تخطيطيا لهذه الشريحة محتويا هذين الجزأين . الجزء المقابل للميكروبروسيسور يحتوى الخطوط التالية :



- خطوط مسار البيانات وعددها 8 خطوط
  - خطوط مسار العناوين وعددها خطان

أما الجزء المقابل للعالم الخارجي فيحتوى الخطوط التالية:

- خطوط البوابة A وعددها 8 خطوط
- خطوط اليواية B وعددها 8 خطوط
- خطوط البوابة C وعددها 8 خطوط (4 خطوط + 4 خطوط)

بإضافة خطى القدرة (Vcc) والأرضى) يصبح عدد خطوط أو أرجل هذه الشريحة 40 رجلا . لاحظ أن البوابة C لها خاصية منفردة عن البوابتين A وذلك لانها يمكن برمجتها كبوابة 8 بتات أو كبوابتين كل منهما 4 بتات أو أنها تستخدم كخطوط تحكم للبوابتين A مما أنه يمكن عمل Set أو Reset لأى طرف مسن أطراف هذه البوابة بالذات كما سنرى فيما بعد . شكل (10-16) يبيسن الرسم الطرفى لهذه الشريحة .

| PC6<br>PC5<br>PC4<br>PC0<br>PC1<br>PC2<br>PC3<br>PB0 | 10<br>11<br>12<br>13<br>14<br>15<br>16<br>17<br>18 | òò | 32<br>31<br>30<br>29<br>28<br>27<br>26<br>25<br>24<br>23 | D2 D3 D4 D5 D6 D7 Vcc PB7 PB6 PB5 |
|------------------------------------------------------|----------------------------------------------------|----|----------------------------------------------------------|-----------------------------------|
| PC4<br>PC0                                           | 13<br>14                                           |    | 28<br>27                                                 | D6<br>D7                          |
| PC3                                                  | 17                                                 |    | 24<br>23                                                 | PB6<br>PB5                        |
| PB2                                                  | 20                                                 |    | 22<br>21                                                 | PB4<br>PB3                        |

من وجهة نظر المعالج فإن الشريحة 8255 تحتوى على أربعة مسجلات أو أربع بوابات أو أربعة أماكن يمكن عنونتها بعنوان خاص لكل منها وهذا هو السبب في

أن الشريحة 8255 لها خطان فقط للعناوين . ثلاثة من هذه المسجلات أو الأماكن هي المسجلات أو البوابات C, B, A وهي التسي تستخدم لإدخسال أو إخسراج المعلومات وهي الثلاث بوابات التي في شكل (01-1) ، أما المسجل الرابع فهو مسجل تحكم Control register والذي عن طريقه يتم التحكم في المسجلات A لجعلها إما بوابات إدخال أو إخراج والتحكم أيضا في طريقة تشغيل الشريحة ككل .

|    |    |    |    |    | العملية              |
|----|----|----|----|----|----------------------|
| A1 | A0 | RD | WR | CS |                      |
| 0  | 0  | 0  | I  | 0  | قراءة من البوابة A   |
| 0  | 1  | 0  | 1  | 0  | قراءة من البوابة B   |
| 1  | 0  | 0  | 1  | 0  | قراءة من البوابة C   |
| 0  | 0  | 1  | 0  | 0  | كتابة في البوابة A   |
| 0  | 1  | 1  | 0  | 0  | كتابة في البوابة B   |
| 1  | 0  | 1  | 0  | 0  | كتابة في البوابة C   |
| 1  | 1  | 1  | 0  | 0  | كتابة في مسجل التحكم |
| X  | х  | х  | x  | 1  | الشريحة غير فعالة    |
| 1  | 1  | 0  | 1  | 0  | حالة غير ممكنة       |
| X  | х  | 1  | 1  | 0  | الشريحة غير فعالة    |

شكل (17-10) عنونة المسجلات في الشريحة x . (355A عنونة المسجلات في الشريحة x

شكل (10–17) يبين كيفية عنونة كل واحد من المسحلات C, B, A وكذاك مسجل التحكم وكيفية القراءة منها أو الكتابة فيها . فمثلا لكى نرسل معلومة إلى مسجل التحكم وكيفية القراءة منها أو الكتابة فيها . A1, A0 ونجعل خط الكتابة  $\overline{WR}$  فعالا بجعله يساوى صفرا وكذلك الخط $\overline{CS}$  وهو خط اختيار الشريحة لابد وأن يكون أيضا فعالا بجعله يساوى صفرا . تتبع طرق القراءة والكتابة في كل واحد يكون أيضا فعالا بجعله يساوى صفرا . تتبع طرق القراءة والكتابة في من هذه المسجلات في شكل (10–17) . لاحظ أن مسجل التحكم يمكن الكتابة فيه فقط و لا يمكن قراءته حيث أن وظيفته لا تتطلب قراءته ، لذلك فإنه يسمى مسجل كتابة فقط و الكتابة و الكتابة فقط و الكتابة فقط و الكتابة فقط و الكتابة و الكت

# 2-5-10 برمجة الشريحة 8255A

إن برمجة الشريحة 8255A لتعمل في أى وضع من أوضاع تشغيلها يتم عن طريق كتابة شفرة من ثماني بتات في مسجل التحكم ، وعلى ضوء هذه الشفرة تصبح أى واحدة من البوابات الثلاث في الوظيفة والحالة mode التي حددت لها

تبعا لهذه الشفرة . تذكر هنا أن من الوظائف الخاصة بالبوابة C أنك يمكنك أن تتشط أو تخمد (set أو reset) أى طرف من أطرافها كما ذكرنا سابقا . شكل (10-18) وشكل (10-19) يبينان وظيفة مسجل التحكم على ضوء الشفرة المخزنة فيه .



يهمنا هنا محتويات البت رقم 7 من مسجل التحكم فإذا كانت هذه البت تساوى واحدا فإن ذلك يعنى أن باقى محتويات مسجل التحكم وهى البت رقم صفر إلى والبت رقم 6 خاصة بتحديد الوظائف المختلفة للبوابات C, B, A على ضوء ما هو مبين فى شكل (10–18) . أما إذا كانت البت رقم 7 من مسجل التحكم تساوى صفرا فإن ذلك يعنى أن الشفرة الموجودة فى باقى البتات خاصة بعمل set وتسمى reset لأحد أطراف البوابة C على ضوء ما هو مبين فى شكل (10–19) وتسمى حالة تتشيط/إخماد البت D و Bit Set Reset و المتعارف عليها بالعربى هكذا (ب D, D).



## مثال 10-1

ما هى الشفرة أو البايت التى نكتبها فى مسجل التحكم للشريحة 8255A للحصول على الآتى :

البوابة B دخل ، والبوابة A خرج ، والبوابة C خرج ، والجميع يعمل في B ، mode D . mode D . mode D الجزء القادم .

بالنظر إلى شكل (10–18) نجد أنه لكى يكون النصف الأول مــن البوابـة C خرجا فإن D=0 ولكى تكون البوابة B دخلا فإن D=1 ولكى تكون المجموعـة B في D=0 فإن D=0 ، بالنسبة للنصف الثانى من البوابة D=0 فلكى يكــون خرجا فإن D=0 ولكى تكون البوابة D=0 فإن D=0 ولكى تكون البوابة D=0 فإن D=0 في D=0 في D=0 في D=0 في D=0 في المحموعة محتويات البايث المطلوبة هي :

#### D7 D6 D5 D4 D3 D2 D1 D0

1 0 0 0 0 0 1 0

بالنظام الستعشرى فإن هذه البايت تكون H وال H تستخدم للدلالــة علــى أن الرقم المجاور لها يكون فى النظام الستعشرى . المطلـوب الآن هـو كتابــة أو إرسال هذا الرقم إلى مسجل التحكم فى الشريحة 8255A . لإرسال هذا الرقم إلى مسجل التحكم فى الشريحة 8255A فإنه كما نعلم أن خطــى العنـاوين A1, A0 مسجل التحكم فى الشريحة 8255A موصلان بخطى العناوين A1, A0 القادمين من شريحة المعالج للشريحة مكل (10-17) أن عنوان مسجل التحكم هو 11 =A1A0 لذلك فإنـه لكى نرسل الرقم المطلوب إلى مسجل التحكم يكفى أن نكتب الأمرين التاليين : MVI A.82H

OUT 03

حيث الأمر الأول سيضع الرقم 82H في مسجل التراكم A والأمر الثاني سيخرج محتويات مسجل التراكم إلى البوابة رقم 3 وهي مسجل التحكم في الشريحة 8255A لأن الرقم 3 سيجعل خطى العناوين A1, A0 يساويان 11 وهذا هو عنوان مسجل التحكم.

بذلك يمكن التعامل مع البوابات C, B, A حسب حالة كل منهم التى تم تحديدها في مسجل التحكم بالرقم 82H. فمثلا الأمر OUT 00 سيخرج محتويات مسجل التراكم على البوابة A لأن عنوان البوابة A هو A1A0=00. وأما الأمر IN 01 الأمر A1A0=00 هو فسيقرأ محتويات البوابة B ويضعها في مسجل التراكم لأن عنوان البوابة B هو فسيقرأ محتويات البوابة C مي OUT 02 فسيقوم بعملية إخراج على البوابة C حيث عنوان البوابة C هو الما الأمر A1A0=01. لاحظ أن العناوين التي استخدمناها للبوابات عنوان البوابة في الأوامر السابقة كانت 00 و 10 و 02 و 03 و كلها أرقاما ستغشرية وليس بالضرورة أن تكون هذه هي الأرقام التي يجب أن تستخدم فقط في جميع الأحوال . النظرية هنا هي أن العنوان الذي نستخدمه يجب أن يحقى الشفرة المطلوبة لكل بوابة على الخطين A1, A0. شكل (10-20) يبين الشريحة المطلوبة لكل بوابة على الخطين A1, A0. شكل (10-20) يبين الشريحة المحلوبة لكل بوابة على الخطين A1, A0. شكل (10-20) يبين الشريحة المحلوبة لكل بوابة على الخطين A1, A0. شكل (10-20) يبين من مسار

العناوين . لاحظ عدم استخدام الخطين A1, A0 في عملية التشفير ولكنهما يوصلان مباشرة إلى الشريحة 8255A .

من شكل (10-20) نتبين العناوين التالية للمسجلات الأربعة:

| العنوان ستعشرى | <b>A7</b> | <b>A6</b> | <b>A5</b> | <b>A4</b> | <b>A3</b> | <b>A2</b> | <b>A1</b> | $\mathbf{A0}$ |    |             |
|----------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|---------------|----|-------------|
| 0E             | 0         | 0         | 0         | 0         | 1         | 1         | 0         | 0             |    | A           |
| 0D             | 0         | 0         | 0         | 0         | 1         | 1         | 0         | 1             | •  | В           |
| 0E             | 0         | 0         | 0         | 0         | 1         | 1         | 1         | 0             |    | C           |
| $\mathbf{0F}$  | 0         | 0         | 0         | 0         | 1         | 1         | 1         | 1             | CR | مسجل التحكم |



Modes تشغيل الشريحة 3-5-10 تشغيل الشريحة 8255A الشريحة 8255A لها ثلاث حالات modes لتشغيلها وهي كالتالى:

## Mode zero الحالة صفر 1-3-5-10

تتميز هذه الحالة بعمليات الإخراج والإدخال البسيطة التي لا تتطلب حسوارا أو نظام مصافحة handshaking بين الشريحة والمعالج ، ففي هذه الحالة يمكن برمجة كل من البوابة A أو B أو C لتكون بوابة إخراج أو إدخال في أي مكنان في البرنامج وعن طريق أمرين اثنين فقط كما سنرى بعد قليل . لاحظ أنه فسي هذه الحالة يمكن برمجة البوابة C كبوابة ثماني بتات أو بوابتين كل منهما أربع بنات . جميع هذه البوابات تكون فيها خاصية المسك latch للمعلومة عندما تعمل كبوابات إخراج ، وأما عندما تعمل كبوابات إدخال فلا تكون فيها هذه الخاصية . باعتبار البوابة C كبوابتين كل منهما 4 بتات فإنه يمكن أن يكون لدينا 4 بوابلت يمكن برمجتها إخراج أو إدخال على حسب الشفرة التي ترسل إلى مسجل التحكم على ضوء ما رأينا في شكل C . شكل C . شكل C . يبين جميع هذه الحالات على ضوء ما رأينا في شكل C . شكل C . شكل C . شكل حالة .

| الشفرة الستعشرية | البوابة | البوابة С | البوابة | البوابة C |
|------------------|---------|-----------|---------|-----------|
| إلى مسجل التحكم  | A       | PC4-PC7   | В       | PC0-PC3   |
| 80               | إخراج   | إخراج     | إخراج   | إخراج     |
| 81               | إخراج   | إخراج     | إخراج   | إبخال     |
| 82               | إخراج   | إخراج     | إدخال   | إخراج     |
| 83               | إخراج   | إخراج     | إبخال   | إدخال     |
| 88               | إخراج   | إدخال     | إخراج   | إخراج     |
| 89               | إخراج   | إدخال     | إخراج   | إدخال     |
| 8A               | إخراج   | إدخال     | إدخال   | إخراج     |
| 8B               | إخراج   | إدخال     | إبخال   | إدخال     |
| 90               | إدخال   | إخراج     | إخراج   | إخراج     |
| 91               | إدخال   | إخراج     | إخراج   | إدخال     |
| 92               | إدخال   | إخراج     | إدخال   | إخراج     |
| 93               | إدخال   | إخراج     | إدخال   | إدخال     |
| 98               | إدخال   | إدخال     | إخراج   | إخراج     |
| 99               | إدخال   | إدخال     | إخراج   | إدخال     |
| 9 <b>A</b>       | إدخال   | إدخال     | إدخال   | إخراج     |
| 9B               | إدخال   | إدخال     | إدخال   | إدخال     |

شكل (10–21) جميع حالات الإدخال والإخراج للبوابات A و B و C والشفرة الستعشرية لكل حالة .

مثال 2-10

شكل (10-22) يبين رسما صندوقيا لدائرة مواجهة مع المحول التماثلي الرقميي ZN427 مستخدما الشريحة 8255A في الحالة 0 المحول ZN427 ليب خطوط تحكم ، أحدها هو خط بداية التحويل Start Conversion; SC وهذا الخط يجب أن يكون صفرا لفترة زمنية وجيزة بحيث يبدأ المحول عملية التحويل عند الحافة الصاعدة لهذه الإشارة . بعد أن ينتهي المحول من عملية التحويل فإنه يعطى نبضة واحد على خط نهاية التحويل Conversion; EOC ولكنه لا يعطى البيانات على خطوط الخرج الثمانية إلا إذا تم إعطاؤه نبضة واحد علي يعطى الميانات على خطوط الخرج الثمانية إلا إذا تم إعطاؤه نبضة واحد علي خط تتشيط الخرج المحول . شكل (10-22) يبين أيضا الترامن الموجود بين الموجود بين الموجود بين الموجود بين الموجود بين الموجود المحول على البوابة . لقد تم توصيل خرج المحول على البوابة A للشريحة خرج المحول .



مطلوب أيضا من المعالج أن يعطى للمحول نبضة بدأ التحويل  $\overline{SC}$  وسيكون ذلك من خلال الخط رقم 0 في البوابة C وسيكون عن طريق استخدام الحالة (ب س ر) التي سنستخدمها لتنشيط الخط PCO كما رأينا في شكل (10–10) . بعـــد أن

يعطى المعالج نبضة بداية التحويل يبدأ في مراقبة خط نهاية التحويل القادم مسن المحول إلى الخط PC5 بحيث عندما يجد المعالج أن هذا الخط صعد إلى الواحد يفهم من ذلك أن المحول انتهى من عملية التحويل فيعطى له إشارة تنشيط الخرج بجعل الخط OE الموصل على PC1 يساوى واحد وذلك أيضا باستخدام طريقة الله (ب س ر) . لذلك فإن النصف الأول من البوابة O سيعمل كبوابة إخراج وأما النصف الثاني فسيعمل كبوابة إدخال . البرنامج التسالي يمكن استخدامه لقراءة خرج مثل هذا المحول . ملاحظة مهمة يجب أن نتذكرها من هذا البرنامج وهي أن إرسال أي شفرة إلى مسجل التحكم لتنشيط أو إخماد أي بت من بتسات البوابة O لا يؤثر على الإطلاق على الحالة التي عليها كل من البوابة A أو B فستبقي إدخالا أو كانت إخراجا فستبقى على الحالة التي عليها سواء كسانت إدخالا أو كانت إخراجا فستبقى كذلك أيضا .

```
هذا الرقم يجعل PCO-PC3 إخراج والبوابة B إخراج
       (B غير مستخدمة في هذا المثال) و PC4-PC7 إدخال والبوابة A إدخال
                                           راجع شكل (10-18).
                                 إخراج الرقم 98H إلى مسجل التحكم
OUT 03H :
START: MVI A,01
             تنشيط الخط PC0 عن طريق ب س ر راجع شكل (10. 19)
OUT 03H ;
              إخراج إلى مسجل التحكم
              عمل إخماد للخط PCO
MVI A,00 ;
OUT 03H ;
                إخراج إلى مسجل التحكم
MVI A,01;
             عمل ست للخط PCO
بذلك يكون الخط نزل من 1 إلى 0 ثم صعد وبذلك نتم نبضة .OUT 03H ; SC
قراءة البوابة XX: IN 10 ; C
هذا لاختبار الخط PC5 لمعرفة إذا كان واحد أم صفر ; ANA 20H
JZ xx
                 قفز إلى xx لمعاودة القراءة طالما أن PC5 يساوى 0 .
MVI A,03H ;
                             · تشيط للخط PC1 لتشيط الخط OE
OUT 03H :
               إخراج إلى مسجل التحكم
إرجاع الخط OE=PC1 إلى الصفر ثانية. ; MVI A,02H
إخراج إلى معىجل التحكم ; OUT 03H
      قراءة البوابة A . ;
IN 00
لإعطاء نبضة بدأ تحويل جديدة ; JMP START
```

### Mode one الحالة واحد 2-3-5-10

في هذه الحالة يتم الإدخال أو الإخراج عن طريق البوابتين A و B فقط ويتـم ذلك عن طريق نظام مصافحة Handshaking أو حوار بين الأجهزة المحيطة والمعالج من خلال الشريحة 8255A وتستخدم خطوط البوابة C فسسى عمليات المصافحة هذه يحيث أن النصف الأول من خطوط البوابة C وهي PCO إلى PC3 تستخدم كخطوط حوار تابعة للبوابة B ولذلك تسمى البوابسة B والنصف الأول من البواية C بالمجموعة B أو Group B . وأما النصف الثاني من خطوط اليواية C فيستخدم كخطوط مصافحة أو حوار تابعة للبوابـــة A ولذلــك تسمى البوابة A والخطوط PC4 إلى PC7 بالمجموعة A . لاحظ أن البوابــة C بأكملها لا يمكن استخدامها هنا في الإخراج أو الإدخال ولكن يمكن استخدام بعض خطوطها أحيانا كما في شكل (10-23) . تتميز هذه الحالة بــأن البيانــات سواء الداخلة أو الخارجة من البوابتين A أو B تمسك latched على هذه البوابات ، كما أن هذه الحالة توفر للمستخدم خطا يمكن منه مقاطعة المعالج . عمليات المقاطعة سندرسها بالتفصيل في فصل خاص بذلك . شكل (23-10) يبين وظيفة كل خط من خطوط البوابة C كخطوط مصافحة لكل من البوابتين A و B في الحالة 1 وذلك عندما تستخدم كل من A و B كبوابة إدخال أو إخراج . شكل (10-24) يبين وظيفة خطوط البوابة C في حالة كون كل من البوابتين A و B بو ابات الدخال فقط ويبين أيضا التزامن بين هذه الإشارات في هذه الحالة . لاحظ أن البوابة B تستخدم الخطوط PCO, PC1, PC2 كخطوط مصافحة بينما تستخدم البوابة A الخطوط PC3, PC4, PC5 كخطوط مصافحة ويتبقى خطــان وهما PC6, PC7 يستخدمان كخطوط إدخال أو إخراج على حسب البت D3 في مسجل التحكم . تتم عملية المصافحة مع الأجهزة المحيطة كما يلى :

• يقوم الجهاز الخارجي بوضع البيانات على البوابة التي يتعامل معها ولتكسن البوابة A مثلا ثم يضع صفرا على الخط STBA ليخبر الشريحة 8255A أنه قد وضع بايت على البوابة A .

• ترد الشريحة 8255A على الجهاز الخارجي بأنها استقبلت المعلومة وتسم مسكها على البوابة A عن طريق جعل الخط IBFA يساوى واحدا . عندما يرى الجهاز الخارجي أن الخط IBFA يقوم بإرجاع الخط STBA إلى الواحد ثانية استعدادا لإرسال بايت أخرى إن أراد . لاحظ أن الخط IBFA لا يسنزل إلى الصفر ثانية إلا إذا تم قراءة المعلومة بواسطة المعالج وذلك عند الحافة الصاعدة للإشارة RD الموصلة بالشريحة 8255A طرف 5.

• تقوم الشريحة 8255A بتوليد إشارة مقاطعة INTRA يمكن بها مقاطعة المعالج في حالة الرغبة في ذلك وذلك بتوصيلها إلى أي خط من خطوط المقاطعة على المعالج. لاحظ أيضا من التزامن في شكل (24-10) أن هذا

الخط يكون واحدا إذا كان الخط  $\overline{STBA}=1$  والخط  $\overline{BF}=1$  والبت  $\overline{PC4}=1$  في حالة التعامل مع البوابة A وأما في حالة البوابية B في البت  $\overline{PC2}=1$ . البتات  $\overline{PC4}$ ,  $\overline{PC4}$ ,



شكل (10-25) يبين نفس الوظائف لخطوط البوابة C ولكن في حالة كون A و الموابت إخراج ويبين أيضا التزامن بين هذه الإشارات . لاحظ أن البوابة B بوابات إخراج ويبين أيضا التزامن بين هذه الإشارات . لاحظ أن البوابة A تستخدم الخطوط PCO, PC1, PC2 كخطوط مصافحة بينما تستخدم البوابة PC4, PC5, PC6, PC7 كخطوط مصافحة ويتبقى خطان وهما PC4, PC5 يستخدمان كخطوط إدخال أو إخراج على حسب البت D3 في مسجل التحكم . تتم عملية المصافحة كما يلى :



• عندما يقوم المعالج بكتابة أى بايت إلى أى من البوابتين A أو B فإنه عنسد الحافة الصاعدة للإشارة WR تقوم الشريحة 8255A بجعل الخط OBFA يساوى صفرا دلالة للمعالج أن هذه المعلومة قد تم مسكها كما في التزامن الموضح في شكل (10-25) وعلى المعالج ألا يرسل معلومات أخرى إلا بعد صعسود هذا الخط للواحد مرة أخرى.



- عندما يرى الجهاز الخارجى أن الخط OBF يساوى صفرا يعرف أن هناك بايت على البوابة وعليه قراءتها فيقوم بجعل الخط ACK يساوى صفرا وإرجاعه مرة أخرى للواحد لكى يخبر الشريحة 8255A أنه قد قرأ المعلومة . لاحظ من التزامن أن الحافة النازلة للخط ACK تتسبب في إرجاع الخط OBF الى الواحد مرة أخرى .
- تقوم الشريحة 8255A بتوليد إشارة مقاطعة 100 يمكن بها مقاطعة المعالج في حالة الرغبة في ذلك وذلك بتوصيلها إلى أي خط من خطوط المقاطعة على المعالج بغرض طلب بايت جديدة منه . لاحظ أيضا من الستزامن في شكل (10-25) أن هذا الخط ينزل إلى الصفر مع الحافة الصاعدة للخط 10 في شكل (10-25) أن هذا الخط ينزل إلى الصفر مع الحافة الصاعدة للخط 10 ويرجع إلى الواحد مرة ثانية عندما يكون كل من الخطين 10 و 10 و

#### مثال 10-3

شكل (10-26) يبين عملية توصيل طابعة مع المعالج من خالل البوابة B للشريحة 8255A وشكل (10-27) يبين البرنامج الذي يقرأ محتويات الذاكرة ابتداء من المكان E150H وانتهاء بالمكان E150H ويرسلها إلى الطابعة للطباعة. إن عملية تشفير البوابات الثلاث ، أي عنونتها سنتركها للقارئ يختار ما يشاء من عناوين للبوابات الثلاثة وسنفترض هنا أن هذه البوابات معنونة كالتالى:



00H A البوابة 01H B البوابة 02H C البوابة مسجل التحكم

في هذا المثال تم استخدام البوابة B فقط وفي الحالة mode واحد وأما البوابة A وباقى البوابة C فيمكن استخدامها لأي أغراض أخرى . السؤال هو : ما هي الشفرة التي سنرسلها إلى مسجل التحكم لنجعل البوابة B إخراج وفي الحالمة D وأما البوابة D وباقى البوابة D فسنفتر ضها إخراج في الحالة D وذلك مع العلم أنها لن تستخدم D الإجابة هي أن هذه الشفرة ستكون كالتالي كما تعلمنا من شكل D

D7 D6 D5 D4 D3 D2 D1 D0 1 0 0 0 0 1 0 0 = 84H

- النصف الأول من البوابة C لا يهم أن يكون إخراجا أو إنخالا وبفرضا إخراجا تم وضع D0=0 .
  - بما أن البوابة B ستكون إخراجا لذلك تم وضع B 1=0.
    - بما أن B ستعمل في الحالة 1 لذلك تم وضع E-D2-1
- النصف الثانى من البوابة C لا يهم أن يكون إدخالا أو إخراجا وبفرضه إخراجا ومع D3=0 .
  - بما أن البوابة A فرضت إخراجا لذلك فإن 0=D4
  - بما أن البوابة A فرضت في الحالة 0 لذلك كان O = D6D5 = 00
    - بما أن هذه الشفرة تستخدم لتوظيف البوابات فإن 1=D7 ·

بالنظر إلى شكل (10-27) نجد أن البرنامج بدأ بإرسال الشفرة 84H كما سبق إلى مسجل التحكم ثم استخدم المسجلين HL كمؤشر إلى الحرف الجاهز للطباعة والمسجل B كعداد تنازلي للأحرف التي سيتم طباعتها بحيث تقف عملية الطباعة عندما يصل هذا العداد إلى الصفر لأن البرنامج ينقص هذا العداد بمقدار واحد كلما تمت طباعة حرف. تبدأ حلقة الطباعة من العلامة NEXT والتي عندها يتم قراءة البوابة C وحجب جميع بتاتها بالقيمة 20 لمعرفة إذا كان الخطط يتم يساوى صفرا أم لا ، لأن صفرا على هذا الخطمعناه أن هناك حرف مازال ممسوكا على البوابة في انتظار الطابعة لاستلامه . بمجرد أن يصبح الخط ممسوكا على البوابة في انتظار الطابعة لاستلامه . بمجرد أن يصبح الخط الى الطابعة والدخول في نفس حلقة قراءة البوابة C مرة أخرى . تتكرر هذه العملية إلى أن ينتهي المعالج من جميع الأحرف المطلوب طباعتها عندما يصل المسجل B إلى الصفر .

# 3-3-5-10 الحالة اثنان Mode two

البوابة A فقط هي التي يمكنها أن تستخدم في هذه الحالة وأما البوابة B فتكون إما في الحالة صفر mode 0 أو في الحالة واحد mode 1 عندما تشتغل البوابة م في هذا الحالة فإنها تسلك مسلك مسار بيانات بمعنى أنها تكون بوابة إخراج إذا كانت المعلومات خارجة وتكون بوابة إدخال إذا كانت المعلومات داخلة وذلك دون استخدام أي أمر أو اللجوء إلى مسجل التحكم لعمل ذلك . لذلك فإن البوابة A عندما تكون في هذه الحالة فإنها تستخدم خمسا من خطوط البوابة C في فظام المصافحة أو الحوار وهذه الخطوط هي PC3 إلى PC7 . إن هذه الحالة هي أعقد الحالات التي تستخدم مع الشريحة 8255A وعادة يستخدم في حالات الاتصال بين حاسبين أو بين المعالج والأقراص الصلبة ولذلك سنكتفي بهذه الإشارة عن هذه الحالة .

```
MVIA,84H ; 0 أخراج في الحالة 1 و A و A أخراج في الحالة B
OUT 03H ;
                                        إرسال إلى مسجل التحكم
                            إشارة لبداية الأحرف المطلوب طباعتها
LXIH,E100;
                                   المسجل B عداد لهذه الأحرف
MVI B,50H;
قراءة البوابة C لمعرفة حالة الخط OBF وهو الخط C إلى NEXT: IN 02
                             حجب لجميع البتات ما عدا PC1
ANI 02H
                      دوران في الحلقة طالما أن PC1=OBF=0
JZ NEXT
                             لحضار حرف ووضعه في المركم
MOV A,M ;
OUT 01H ;
                               إخراج على اليوابة B (الطابعة)
INX H
                                     إشارة إلى الحرف التالي
DCR B
                                       إثقاص العداد بمقدار 1
JNZ NEXT ;
                                     قفز لطباعة الحرف التالي
```

شكل (10-27) برنامج الطابعة الموصلة في شكل (10-26)

# 10-6 تسماريسن

- 1. ما المقصود بالإدخال والإخراج ؟
- 2. ما هو الفرق بين الإدخال والإخراج والكتابة والقراءة من الذاكرة ؟
- 3. أيهما أسرع ، إرسال واستقبال البيانات على التوالى , أم على التوازى ؟ اذكر بعض التطبيقات التى تستخدم كل نوع ؟

- 4. عند تنفيذ المعالج للأمر OUT 00 مثلا ، فإنه يقوم بالتأثير علسى المسارات الثلاثة ، اذكر هذه التأثيرات ؟
- 5. عند تنفيذ المعالج للأمر 10 IN مثلا ، فإنه يقوم بالتأثير على المسارات الثلاثة ، اذكر هذه التأثيرات ؟
- 6. أعد رسم شكلى (10-7 و -10) مستخدما فاكك شفرة decoder بــد لا مـن مقار ن العناوين ؟
- 7. أعد رسم شكلى  $(01-9 \ e \ 10-10)$  مستخدما فاكك شفرة decoder بدلا مـــن مقارن العناوين ؟
- 8. مطلوب توصيل بوابة إخراج واحدة فقط وأخرى إدخال على المعالج ، ارسم أبسط دائرة للتوصيل ؟
- و. ما هو المقصود بالتشفير الكامل والتشفير الناقص ؟ من أى أنــواع التشـفير
   تكون الدائرة التي وصلتها في السؤال الثامن ؟
- 10. عند تنفيذ المعالج للأمر STA adr مثلا ، يقوم بالتأثير على المسارات الثلاثة ، اذكر هذه التأثيرات ؟ كيف يمكن استغلال هذه التأثيرات لبناء بوابة إخراج ؟
- 11. عند تنفيذ المعالج للأمر LDA adr مثلا فإنه يقوم بالتأثير علي المسارات الثلاثة ، اذكر هذه التأثيرات ؟ كيف يمكن استغلال هذه التأثيرات لبناء بوابة ادخال ؟
- 12. ماذا تعنى خريطة الذاكرة لأى ميكروكومبيوتر ؟ ارسم خريطة الذاكرة للميكروكومبيوتر الذى تستخدمه وادرسها جيدا ؟
- 13. أعد رسم شكلى (10-12 و 10-13) مستخدما مقارن عناوين بدلا من فاكك الشفرة decoder ؟
- 14. هل يمكن بناء بوابة إخراج تأخذ نفس عنوان أحد أماكن الذاكرة الموجودة فعلا ؟
- 15. هل يمكن بناء بوابة إدخال تأخذ نفس عنوان أحد أماكن الذاكرة الموجودة فعلا؟
- 16. من وجهة نظر المعالج فإن الشريحة 8255A تتكون من 4 مسجلات يمكن القراءة منها والكتابة فيها ، هل هذه العبارة صح أم خطأ ؟
- 17. هل من الضرورى أن تكون عناوين البوابات  $\dot{A}$  و  $\dot{B}$  و  $\dot{A}$  متتابعة أى  $\dot{A}$ 5 و  $\dot{A}$ 5 و  $\dot{A}$ 5 و  $\dot{A}$ 5 مثلا وذلك في الشريحة  $\dot{A}$ 8255A و  $\dot{A}$ 5 و  $\dot{A}$ 5 مثلا وذلك في الشريحة  $\dot{A}$ 5 و  $\dot{A}$ 5 و  $\dot{A}$ 5 مثلا وذلك في الشريحة  $\dot{A}$ 5 و  $\dot{A}$ 5 و  $\dot{A}$ 5 مثلا وذلك في الشريحة  $\dot{A}$ 5 و  $\dot{A}$ 5 و  $\dot{A}$ 5 مثلا وذلك في الشريحة  $\dot{A}$ 5 و  $\dot{A}$ 6 و  $\dot{A}$ 7 و  $\dot{A}$ 6 و  $\dot{A}$ 7 و  $\dot{A}$ 8 و  $\dot{A}$ 9 و  $\dot{A}$ 9
- 18. هل يمكن استخدام الشريحة 8255A وعنونتها بطريقة خرائط الذاكرة ؟ أم أنه لابد من استخدامها مع الأمرين IN و OUT ؟
  - 19. اشرح مع التبسيط الحالات modes الثلاثة لتشغيل الشريحة 8255A ؟

# الفصل الحادى عشر

دراسة لباقى أطراف المعالج من خلال عروم وراسة لباقى أطراف المعالج من خلال عليه والمعالج من خلال المعالج من خلال المعالج من خلال المعالج من خلال المعالج المعال

## 1-11 مقدمة

إنه في الكثير من الأحيان وعند نكر التطبيقات التي تستخدم الميكروكومبيوتر للتحكم في أي عملية صناعية يتبادر إلى ذهننا فورا الميكروكومبيوتر بصورتك المركبة والمعقدة حيث الشاشة ولوحة المفاتيح والطابعة ووحدة التحكم المركزي cpu والكمية الهائلة من الذاكرة التي قد تصل إلى الكثير من الميجابايتات ، فصي حين أن العملية من الممكن أن تكون أبسط من ذلك بكثير كما سنرى . سنحاول في هذا الفصل أن نقدم عرضا مفصلا وشرحا دقيقا لدائرة المعالج على كارت اليكتروني واحد one board وهذا الكارت يمكن استخدامه في الكثير من أغراض التحكم ومنها على سبيل المثال عملية التحكم في متغيرات تتك تقطير المياه التسي خكرناها في مقدمة الفصل العاشر وسوف نستخدم هذه الدائرة في هذا الفصل في عملية التحكم في إشارة مرور رباعية كتطبيق على ذلك .

# 11-2 تركيب الدائرة

إن الميكروكومبيوتر بمعناه العام والشامل وكما ذكرنا في الفصل الأول من هذا الكتاب يتركب من شاشة للعرض ولوحة مفاتيح ووحدة تحكم مركزى cpu وكمية من الذاكرة تقل أو تكثر على حسب متغيرات وأوضاع كثيرة . إن الكثير من التطبيقات وبالذات التي تستخدم المعالج في أغراض التحكم لا تحتاج إلى كلى هذه الإمكانيات ، فما فائدة شاشة العرض مثلا في دائرة نريد تصميمها للتحكم في سرعة محرك والحفاظ على ثباتها ؟ أو ما فائدة لوحة المفاتيح أو الكمية الهائلسة من ال RAM في دائرة نريد تصميمها للتحكم من الهمكانيات التي نستطيع معين داخل مدينة ؟ من هنا كان السؤال عن ما هي أقل الإمكانيات التي نستطيع بها أن نصمم دائرة تكون سهلة البناء ، رخيصه التكاليف ، وتفي بمعظم التطبيقات التي تحتاج إلى المعالج كعنصر أساسي في تطبيقات التحكم الآلي ؟

تتكون أى دائرة تستخدم المعالج في أغراض التحكم العامة من الأجزاء التالية: 1. المعالج وقد تم تهيئة جميع مساراته لعملية المواجهة مع الأجهزة المحيطة

2. شريحة ذاكرة EPROM تحتوى البرنامج الذى سيقوم بالعملية التى تستخدم من أجلها دائرة المعالج .

3. شريحة RAM قد تكون هناك الحاجة إليها من قبل البرنامج السابق ، وإذا لـم تكن هناك حاجة إليها يمكن في هذه الحالة الإستغناء عنها .

4. عدد من بوابات الإدخال والإخراج على حسب الحاجة والتطبيق الذى تستخدم من أجله الدائرة المذكورة .

لكى نفهم طريقة عمل هذه الدائرة فنحن نعلم أن المعالج عند إعطائه نبضة RESET أو عند بداية تشغيلة يبدأ التنفيذ من عنوان معين وهذا العنوان يختلف من معالج لأخر ، فإذا جعلنا هذا العنوان هو أول عنوان فى البرنامج الذى كتبناه لهذا الغرض (غرض التحكم فى أى عملية صناعية) والموجود فى شريحة ال BPROM والتى تم توصيلها بحيث تعمل مع هذا العنوان ، فإنه بمجرد تشعيل المعالج سينفذ البرنامج ويتعامل مع بوابات الإدخال والإخراج وعلى حسب ظروف العملية التى صمم من أجلها . المفروض طبعا أن هذا البرنامج سيكون برنامجا يدور فى حلقة لا نهائية تجعل المعالج فى حالة تتفيذ مستمرة للبرنامج .

11-2-11 مثال توضيحي

كمثال على ذلك سنقوم فى هذا الفصل إن شاء الله بعمل نظام تحكم فــى إشــارة مرور فى تقاطع رباعى كالمبين فى شكل (1-1) بحيث يحتوى كــرت التحكـم على مفتاح (خط تحكم يدوى يستعمل بواسطة رجل المرور عند اللزوم) ، بحيـت عندما يكون هذا المفتاح واحدا فإن الإشارات تعمل فى الوضع الطبيعى وعندمــا يكون هذا المفتاح صفرا فإن اللون الأصفر فى جميع الإتجاهات يضىء ويطفــىء يكون هذا المفتاح معين وليكن نصف ثانية .

سنقوم هنا ببناء الدائرة مستخدمين المعالج 8085 بعد تجربتها والتأكد من صحتها معمليا ، وسنترك القارىء حرية إعادة بناء الدائرة مستخدما إما المعالج 280 أو أى معالج آخر إذا كان يفضل العمل بأحدها وسوف نشيير إلى أى معلومات ضرورية لذلك في حينها .

سيقوم المعالج لحل هذه المشكلة بادارة عدد 12 لمبة في الأركان الأربعة من التقاطع منها أربعة باللون الأخضر Green, G ، واحدة في كل ركن ، وأربعة باللون الأحمر Red, R ، واحدة أيضا في كل ركن كما هو مبين في شكل (1-1) . لإنارة هذا العدد من اللمبات (12) سنحتاج إلى بوابتي إخراج سنستخدم منهما 12 بت للمبات والأربع بتات الباقية سنتركها بدون استخدام حاليا أو لما قد يجد في المستقبل من إضافات بالنسبة للدائرة . بالنسبة لمفتاح التحكم الذي سيشغل الإشارة إما في الوضع الطبيعي أو الوضع الترددي flashing فإننا سنحتاج لبوابة إدخال يقرأ منها المعالج قيمة هذا المفتاح باستمرار قبل البدء في أي دورة من دورات الإشارة كما سنري بعد قليل . لذلك فإننا سنحتاج للشرائح التالية لكي نتم عملية بناء دائرة التحكم في الشارة المرور :

• شريحة المعالج 8085 Intel وقد وصلت جميع أطرافها إلى الجهد المناسب (سواء أرضى أو Vcc) وسنرى كيفية توصيل هذه الأطراف في الجزء القادم .

- شريحتين 74374 لفصل buffer مسار العناوين وقد رأينا ذلك فـــى الفصــل الثامن .
  - شريحة 74245 لفصل buffer مسار البيانات كما في الفصل الثامن أيضا .
- شريحة 74138 وشريحة 74125 للحصول على خطوط التحكم MEMR و MEMR و IOR وقد رأينا ذلك أيضا في الفصل الثامن .
- ثلاث بوابات ، وهذه قد فضلنا أن نحصل عليها من الشريحة 8255A التي شرحناها في الفصل العاشر .
- شريحة EPROM وهي الشريحة 2716 التـــي تحتـوى علــي 2 كيلوبــايت EPROM حيث سيتم حرق (كتابة) البرنامج عليها .
- بعض الشرائح البسيطة مثل 7408 وهي AND وشريحة عاكس التي نحتاجها لعملية التشفير المبسطة للبوابات وشريحة الذاكرة .
- القليل من المقاومات والمكثفات كما سنرى بعد قليل فى الدائرة الكاملة لـــهذا الكارت . سنطلق على هذه الدائرة إسم دائرة الميكروكومبيوتر ذى الكارت الواحد one board microcomputer .



يجب على مستخدمى المعالج Z80 والمعالجات الأخرى أن يراعوا استخدام الشرائح المناسبة كما رأينا في الفصل الثامن عند فصل مسارات كل واحد من هذه المعالجات.

عند تتفيذ هذا الكارت ستواجهنا بعض الأطراف لشريحة المعالج التى لا نعرف وظيفتها بالضبط لأننا لم ندرسها حتى الآن ولذلك فإننا لا نعلم ماذا نفعل بهذه الأطراف ، هل نتركها مفتوحة floating أم هل نوصلها بالأرضى أم Vcc. الجزء القادم من هذا الفصل سنشرح فيه وظيفة كل طرف من هذه الأطراف وماذا نفعل به على الكارت وذلك لكل واحد من المعالجين 8085 و 280 وذلك قبل أن ندخل في تفاصيل حل مثال إشارات المرور.

# 3-11 الأطراف الأخرى للمعالج 8085

لقد درسنا في الأجزاء السابقة وظيفة أطراف المسارات الثلاثة للشريحة 8085 (40 طرفا) وهي كالتالي:

- 1. أطراف مسارى العناوين والبيانات وعددها 16 خط.
- أطراف التحكم وعددها 3 خطوط (WR, RD, IO/M).
  - 3. الطرف ALE.
  - 4. طرفان القدرة Vcc والأرضى .

مجموع هذه الأطراف هو 22 طرفا ويتبقى 18 طرفا لم نعلم عنها شيئا حتى الآن وسنقوم في هذا الجزء بشرح سريع لوظائف هذه الأطراف المتبقية . شكل (11-2) يبين إعادة لرسم أطراف الشريحة 8085 لتسهيل عملية المتابعة .

# 1-3-11 إشارات التزامن Clock signals

الشريحة 8085 تحتوى على مذبذب وهذا المذبذب يأخذ تردداته من بللـــورة أو كريستال crystal توصل بين الطرفين 1 و 2 للشريحة . هذا المذبذب ينتج عنـــه موجة جيبية ذات تردد يساوى 4 ميجاهرتز ، الشريحة 8085 تحتاج إلى نبضات تزامن مربعة وذات تردد يساوى 2 ميجاهرتز ولذلك فإنه وكما هو موضح فـــى شكل (11-3) فقد وصل خرج المذبذب الجيبي على مقارن من نوع شميت ليقوم بتحويل الموجة الجيبية إلى موجة مربعة ثم بعد ذلك أدخلت هذه الموجة المربعـة على قاسم ليقوم بقسمة تردد الموجة المربعة على 2 فنحصل عند خـرج القاسم على موجة مربعة ذات تردد 2 ميجاهرتز حيث تستخدم هذه الموجة فــى جميـع أغراض التزامن والتشغيل داخل الشريحة 8085 . شــكل (11-3) يبيـن كيفيــة الحصول على هذه النبضات . هناك الكثير من الشـــرائح المحيطــة والمسـاعدة الشريحة 8085 والتى تحتاج إلى نفس نبضات التزامن التي تعمل عليها ، لذلـــك

فقد تم إخراج نبضات التزامن على الطرف 37 لشريحة المعالج لكى تتمكن الشرائح والأجهزة المحيطة من الإستفادة منها .

| X1 X2 Reset out SOD SID TRAP RST7.5 RST6.5 RST5.5 INTR INTA AD0 AD1 AD2 AD3 AD4 AD5 AD6 AD7 Vss | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 085 \$\frac{1}{4}\$ | المعالج 8082 | 40<br>39<br>38<br>37<br>36<br>35<br>34<br>33<br>32<br>31<br>30<br>29<br>28<br>27<br>26<br>25<br>24<br>23<br>22<br>21 | Vcc HOLD HLDA CLK OUT Reset in READY IO/M S1 RD WR ALE S0 A15 A14 A13 A12 A11 A10 A9 A8 |
|-------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|--------------|----------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|
|-------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|--------------|----------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|

# 2-3-11 وإعادة تشغيل المعالج

# Starting and reseting the processor

عند وضع صفر على الطرف 36 للشريحة 8085 وهو الطرف RESET IN فإن عداد البرنامج داخل الشريحة يصبح 0000H (ستعشرى) وعند عودة هذا الطوف الى الواحد فإن المعالج يبدأ تنفيذ البرنامج الخاص بإعادة التشغيل والموجود عند المكان 0000H في الذاكرة . شكل (11-4) يبين دائرة يمكن استخدامها في عملية بدأ وإعادة التشغيل . عند بدء التشغيل فإن المكثف C يشحن من خلال المقاومة RI إلى أن يصل جهده إلى القيمة high أو الواحد الثنائي عندها تبدأ الشريحة في العمل من العنوان 0000H كما ذكرنا . إن هذا التأخير الناتج من شحن المكثف

يعتبر ضروريا حتى نضمن عدم تشغيل الشريحة قبل أن يستقر الجهد وحتى نتلافى المشاكل اللحظية Transients التي تحدث عند بدأ التشغيل.





يمكن في أي وقت أثناء عمل الشريحة 8085 إرسال إشارة إعادة تشغيل إليها من خلال الطرف 36 عن طريق قفل المفتاح S2 حيث عندها يبدأ المكثف C في

التفريغ من خلال المقاومة R2 وطالما أن المفتاح S2 مغلق فإن الشريحة R2 الن تعمل . عند ترك المفتاح S2 يفتح يبدأ المكثف C في عملية الشحن من خلال المقاومة R1 حيث تبدأ خطوات إعادة التشغيل التي شرحناها سابقا . يمكن رؤيــة عملية بدء وإعادة التشغيل على مبين الذبذبات كما في شكل C.

| RESET IN=0                | RESET IN =1                    |
|---------------------------|--------------------------------|
| المعالج لا يعمل الطرف ALE |                                |
| شارة ALE على مبين نبذبات  | شكل (11–5) الإشارة RESET IN وا |

كما نعلم فإن الطرف ALE في أثناء عمل الشريحة 8085 يجب أن تكون عليه موجة مربعة تعكس حالة الإشارة الموجودة على أطراف المسارات ADO-AD7 ، فإذا كان هذا الخط low فإن الإشارة تكون بيانات ، أما إذا كان هذا الخط high فإن الإشارة تكون عناوين وكما نعلم فإن المعالج أثناء عمله لابد وأن يكون في حالة تعامل مع بيانات أو عناوين لذلك فإننا يجب أن نرى موجة مربعة على الخط ALE وهذه يمكن استخدامها للدلالة على أن المعالج يعمل . شكل (11-5) يبين الإشارة الموجودة على الطرف ALE مع الإشارة الموجودة على الطرف بين الإشارة الموجودة على الطرف ALE وعند رجوع طرف بدء التشغيل إلى الهيس هناك أي إشارة على الطرف ALE وعند رجوع طرف بدء التشغيل إلى الهيس هناك أي إشارة على الطرف ALE وعند رجوع طرف بدء التشغيل إلى الهيل العمل .

### HLDA و HOLD و HLDA

لكى يتم اتصال بين أى جهاز خارجى والذاكرة فإن ذلك يكون عادة عن طريق المعالج ، حيث يأخذ المعالج المعلومة من الجهاز الخارجى من خلال مسار البيانات ويقوم بإرسالها إلى المكان المحدد في الذاكرة من خلال مسار البيانات ويمساعدة مسارى العناوين والتحكم . هذه الطريقة من الإتصال تسمى بطريقة الإتصال غير المباشر مع الذاكرة حيث يكون الإتصال عن طريق المعالج . هناك طريقة الاتصال المباشر Direct Memory Access, DMA والتسى يقوم فيها الجهاز الخارجي بإرسال معلوماته مباشرة إلى الذاكرة دون اللجوء إلى المعللج .

من أمثلة ذلك نسخ المعلومات من ذاكرة الحاسب إلى الإسطوانة اللينة Flopy disk و العكس . في حالة الإتصال المباشر بالذاكرة فإن المعالج يجب عليه في هذه الحالة أن ينعزل أو يترك أو ينفصل عن المسارات جميعها ليستخدمها الجهاز الخارجي في عملية الإتصال بالذاكرة وحتى لا يحدث أي تصدام في المعلومات على هذه المسارات . عندما يحتاج الجهاز الخارجي للمسارات ليقوم من خلالها بالإتصال المباشر بالذاكرة فإنه يخبر المعالج بذلك عن طريق اعطاء إشارة High على الخط HOLD . كلمة Hold تعني امسك أو قف أو تجمد عليي وضعك الحالى وهذا هو ما يحدث فعلا المعالج . عندما يتبين المعالج وجود high على الطرف HOLD و هو الطرف رقم 39 فإنسه يقوم بإنهاء دورة الماكينة Machine cycle الحالية والتي يقوم بتنفيذها ثم يوقف تنفيذ البرنامج ويضع جميع خطوط المسارات في حالة المقاومة العالية وهي حالة العزل أو الانفصال ويتجمد على هذا الوضع إلى أن يعود الخط HOLD إلى الصفر مرة أخرى . بذلك يكون المعالج قد انفصل عن المسارات ، وعند ذلك فإنه يعطى إشارة للدلالة على أنــه انفصل عن المسارات عن طريق وضع الخطرقم 38 وهو HLDA في وضع ال high أي واحد . HLDA تعنى الاعتراف بحالة التجمــد HLDA تعنى الاعتراف بحالة التجمــد خط ال HOLD أن ينتبع الإشارة الموجودة على الخط HLDA ، فعندما يصب هذا الخط واحدا فإن ذلك يعنى أن المعالج قد انفصل عن المسارات وعندها فقــطّ يستطيع الجهاز الخارجي أن يستخدم المسارات . يمكن استخدام الخطط HLDA أيضا بحيث عندما يكون واحدا فإنه يضع جميع الشرائح المستخدمة فسي عملية فصل المسارات الثلاثة في الحالة الثالثة وهي حالة المقاومة العالية . في دائسرة الميكر وكومبيوتر التي سنبنيها نريد أن يكون المعالج في حالة عمل مستمر ولــن نقاطعه أبدا أو نطلب منه مساراته ، ولذلك سنوصل خط الدخل HOLD بالحالـــة low أي غير فعال ، وخط الخرج HLDA سنتركه مفتوحا ولن نوصله بأي شيء لأنه يمثل إشارة خرج من المعالج وتركه مفتوحا لن يؤثر على عمل المعالج .

### 4-3-11 الطرف READY

إن جميع أجهزة الميكروكومبيتر تكون بها إمكانية تنفيذ البرامج بنظام الخطوة بخطوة Step by step execution في حالة تعاملها بلغة الأسمبلي . في هذا النظام فإن المعالج ينفذ خطوة أو أمرا واحدا من البرنامج بعد إعطائه الأمر بذلك تم ينتظر أمرا آخر لكي ينفذ الخطوة التالية وهكذا . إن المعالج بعد تنفيذ أي أمر يدخل في حالة انتظار Waiting إلى أن يجيئه الأمر بتنفيذ الخطوة التالية . في التناء حالة الانتظار تبقى آخر إشارة وضعت على المسارات كما هي ولا تتغيير حتى أنه بعد الإنتهاء من حالة الانتظار يستأنف المعالج عملية التنفيذ من نفس

المكان الذي توقف عنده . السؤال الآن كيف نستطيع إدخال المعالج في حالية الانتظار هذه؟ إن ذلك يتم عن طريق الطرف رقم 35 من الشريحة 8085 وهيو الطرف READY بمعنى جاهز أو مستعد . إن المعالج قبل تنفيذ أى أمير يقوم الطرف READY بمعنى جاهز أو مستعد . إن المعالج قبل تنفيذ الأمير وإن كيان باختبار الطرف READY في حالة READY في حالة الطرف READY في حالة العظار كما شرحنا . يجب هنا أن نفرق بين حالة الانتظار الناتجية مين صفر يوضع على الطرف READY وحالة ال HOLD التي رأيناها في الجزء السابق . في حالة HOLD ينفصل المعالج تماما عن المسارات وتكون جميع المسارات في وضع المقاومة العالية . أما في حالة الانتظار التي نحن بصددها هنا فلا ينفصل المعالج عن المسارات ولكن تبقى المسارات حاملة لأخر إشارة تم وضعها علي المسارات قبل أن يكون الخط READY صفرا . في دائرة الميكر وكومبيوتر التي سنبنيها نريد المعالج أن يكون في حالة عمل مستمر ولذلك فسوف نضيع الخيط سنبنيها نريد المعالج أن يكون في حالة عمل مستمر ولذلك فسوف نضيع الخيط READY

## 51, S0 طرفي الحالة S1, S0

الإشارة الموجودة على هذين الخطين تبين حالة المعالج عند أى لحظة من الاشارة الموجودة على هذين الخطين تبين حالة من الأربع حالات الآتية :

1. حالة انتظار Waiting وهذه كما رأينا تكون عندما نضع صفرا أو low على الخط READY .

2. حالة كتابة سواء كانت كتابة في ذاكرة أو بوابة إخراج.

حالة قراءة أمر من الذاكرة وتكون هذه في أثناء دورة إحضار الأمر

4. حالة قراءة معلومة سواء كانت المعلومة في الذاكرة أو في بوابة إدخال .

شكل (11-6) يبين الشفرة الموجودة على هذين الخطين في مقابل كل حالة مسن الحالات الأربع . لاحظ أن الإشارة الموجودة على هذين الخطين تكون خارجة من المعالج ولذلك فإننا في دائرة الميكروكومبيوتر التي سنبنيها سسنترك هذين الخطين مفتوحين ولن نوصلهما بأي توصيلات خارجية .

| حالة المعالج       | S1 | · S0 |
|--------------------|----|------|
| انتظار Waiting     | 0  | 0    |
| كتابة Write        | 0  | 1    |
| قراءة Read         | 1  | 0    |
| قرائة أمر Fetching | 1  | 1    |

شكل (11-6) الحالات المختلفة للشريحة 8085

## 6-3-11 أطر اف المقاطعة 6-3-11 أطر اف المقاطعة 6-3-11

يمكن استخدام خطوط المقاطعة لإيقاف المعالج من تنفيذ البرنامج السذى يقوم بتنفيذه الآن وجعله يذهب لتنفيذ برنامج آخر يسمى برنامج خدمة المقاطعة وبعد الانتهاء من تنفيذ برنامج خدمة المقاطعة يعود المعالج إلى البرنامج الأصلى حيث يستأنف تنفيذه من نفس المكان الذى حدثت عنده المقاطعة . لقد أفردنا فصلا كاملا للمقاطعة لمن يريد تفاصيل وأمثلة عن هذا الموضوع ، وما يهمنا الآن هو ماذا سنفعل بهذه الخطوط الآن ؟ إذا كنا نريد استخدام المقاطعة في البرنامج الذي سنستخدمه مع الميكر وكومبيوتر الذي ننوى بناءه في هذا الفصل فعلينا أن نرجيء عملية بناء الدائرة لحين مراجعة الفصل الخاص بالمقاطعة ، أما إذا كنا لسن نستخدم المقاطعة (كما هي الحال في المثال الذي نحن بصدده) فإن جميع هذه الخطوط يجب أن توضع في حالة عدم الفعالية وهذه الحالة تكون عند توصيل الخطوط بالأرضي أي الالله على المقاطعة هي الدائرة الكاملة للميكر وكومبيوتر في آخر هذا الفصل .

## SOD, SID الطرفان 7-3-11

الشريحة 8085 يمكنك أن تستقبل منها أو ترسل إليها بيانات تتابعية الاخسال ببت بعد بت وليس بنظام البايت كما عرفنا سابقا . لن نتكام عن عملية إدخسال وإخراج البيانات تتابعيا في هذا الكتاب ولكن الذي يهمنا هنا هو أن نعرف أن البيانات التتابعية تخرج من المعالج على الطرف SOD الذي يعنى Serial Output بعد وضعها في مسجل التراكم وأما البيانات المراد إدخالها تتابعيا فإنها تدخل على الطرف SErial Input Data ومنه إلى مسجل التراكم مذان الطرفان لن يكون لهما أي فعالية في دائرة الميكر وكومبيوتر ذي الكارت الواحد ولذلك فإننا سنتركهما مفتوحان حيث أنهما لن يؤثرا على تشغيل المعالج والتي حال ، لاحظ أن جميع الخطوط التي تحمل إشارة خرج من المعالج والتي لن يتم استخدامها يجب أن نتركها مفتوحة و لا يتم توصيلها بأي شيء (الأرضي أو الله يمكن أن يؤثر على عمل المعالج بما لا تحمد عقباه .

# 4-11 الأطراف الأخرى للمعالج Z80

### 1-4-11 أطراف المقاطعة RESET, BUSRO, INT, NMI

جميع هذه الأطراف تعتبر مداخل للالمعالج يمكن مقاطعته من عليها وجميع هذه الأطراف تعتبر مداخل للالمعالج يمكن مقاطعته من عليها وجميع المعالم عند الصفر عميع هذه الخطوط في الكارت الواحد لن تستخدم المقاطعة أصلا فإننا سنضع جميع هذه الخطوط في

حالة خمول بتوصيلها إلى Vcc أي high مع العلم أن فصل المقاطعة فـــى هـذا الكتاب خاص بعمليات المقاطعة لمن يريد الإستزادة في هذا الموضعوع . الدى يهمنا معرفته هنا هو العنوان الذي يقفز إليه المعالج عند عمل RESET له أو عند إعادة القدرة إليه ؟ عند إعطاء نبضة على الطرف RESET يقفز المعالج 280 إلى العنوان 0000H حيث يبدأ تتفيذ البرنامج الموجود في هذا المكان ، لذلك يمكن توصيل هذا الطرف بدائرة كالمبينة في شكل (11-4) والتي استخدمناها لعمل RESET للبروسيسور 8085 . الخطان BUSRQ و BUSACK يكافئان الخطان HOLD و HLDA في حالة المعالج 8085 حيث يمكن لأي جهاز خارجي بجعل الطرف BUSRQ فعالا low أن يطلب من المعالج التخلي عن المسارات ووضعها في الحالة المنطقية الثالثة حتى يتسنى للجهاز الخارجي إستعمالها فـــى التعـامل المباشر مع الذاكرة مثلا . Bus Requist تعنى طلب المسارات Bus Requist عندما يتخلى المعالج عن المسارات يقوم بوضع صفر low على الخط BUSACK والذى منه يعرف الجهاز الخرجى أن المعالج قد تخلى فعسلا عن المسارات وتركها وكلمة BUSACK تعني اعترافا بطلب التخلي عين المسارات Bus Acknowledge . في حالة استخدام المعالج Z80 فسي دائرة الميكر وكومبيوتر المقترحة يجب أن يوضع الخط BUSRQ في حالة خمول أو عدم فعالية بتوصيلة على Vcc أي high . أما الخط BUSACK فطالما أنه خط خرج فيجب أن يسترك مفتوحا open و لا يوصل بشيء .

### 2-4-11 الطرف RFSH

يستخدم هذا الخط فى عملية تجديد محتويات الذاكرة الديناميكية dynamic كل فترة زمنية محددة ، وطالما أن هذا الخط يعتبر خط خرج أى يحمل إشارات خارجة من المعالج فإننا سنتركه مفتوحا طالما أننا لن نستخدم هذا النوع من الذاكرة فى الدائرة المقترحة ولا ننوى الدخول فى تفاصيل عملية المواجهة مع الذاكرة الديناميكية هنا .

#### 3-4-11 الطرف HALT

الخط HALT خط خرج ويكون فعالا عندما يكون المعالج في حالــة HALT أى توقف عن العمل بعد تتفيذ الأمر HALT ولا يخرج المعالج من هذه الحالــة إلا عن طريق مقاطعة وطالما أنه خط خرج فسنتركه مفتوحا open .

### 4-4-11 الطرف WAIT

يستخدم هذا الخط في إدخال المعالج في حلقة إنتظار حيث يتوقف فيها المعالج عن تتفيذ أي أمر ولا ينفصل عن المسارات ويمكن استخدام هذا الطرف في تنفيذ

البرامج بنظام الخطوة خطوة مثل الطرف READY في المعالج 8085 وأيضا عندما تكون الأجهزة المحيطة غير مستعدة للتعامل مع المعالج بسبب فارق السرعة مثلا . هذا الخط يكون فعالا عندما يكون صفرا أي أنه المقترحة ولذلك فإننا يجب أن نوصله على Vcc في دائرة الميكروكومبيوتر المقترحة لنجعله غير فعال .

### M1 -4-11 الطرف 11

هذا الخط هو خط خرج يبين حالة المعالج حيث يكون فعالا عندما يكون المعالج في حالة إحضار الأوامر من الذاكرة وهذا الخط لن نستخدمه في دائرتنا ولذلك سنتركه مفتوحا open .

### 6-4-11 الطرف CLK

يستخدم هذا الخط لإدخال نبضات التزامن الخاصة بالمعالج وهي نبضات TTL يتراوح ترددها بين 2.5MH أو 6MH وذلك على حسب نوع المعالج المستخدم.

بذلك نكون قد انتهينا من التعرف على جميع الأطراف الأخرى للبروسيسور Z80 وعرفنا فكرة موجزة عنها ونستطيع أن نلخص القول فى أن جميع خطوط الخرج الغير مستخدمة يجب أن تترك مفتوحة open وجميع خطوط الدخل الغير مستخدمة توضع فى وضع خمول أى عدم فعالية .

## 11-5 إشارات المرور

الآن بعد أن عرفنا وظيفة كل طرف من أطراف المعالج وماذا سنفعل بكل طرف من الأطراف الغير مستخدمه ، ماذا عن دائرة المعالج التي ستتحكم في إشارة المرور كما ذكرنا في المثال التوضيحي ؟ قبل أن ندخل في تفاصيل بناء أو حلى هذه المسألة سننفق بعض الوقت في التفكير في خطة الحل . إن حل هذه المسألة كباقي المسائل التي تستخدم المعالج يتكون من جزء بناء الدائرة hardware وجزء برمجة software . بالنسبة لجزء البناء وكما أشرنا في بداية الفصل فإننا سنحتاج لما يلي :

1. المعالج وقد تم فصل جميع مساراته ، مسار البيانات D0 إلى 50 ومسار العناوين A0 إلى A15 ومسار التحكم بالإضافة إلى خط إعادة الوضع . سنستخدم كما ذكرنا المعالج 8085 كمثال ومن يريد استخدام أى معالج آخر فذلك أصبح سهلا جدا بعد قراءة هذا الفصل . ولقد رأينا في الفصل الثامن كيفية فصل

المسارات الثلاثة ويمكن مراجعة ذلك وبالذات للمعالج 8085 الذي سنستعمله في هذا المثال. شكل (11-7) يبين المعالج والشرائح المستخدمه في عملية الفصل. 2. إشارة المرور الرباعية كما رأينا بها 12 لمبة (ثلاثة في كل ركن من أركان التقاطع ، أحمر وأخضر وأصفر) ومطلوب إدارة هذه اللمبات بتتابع معين وأزمنة محسوبة كما سنرى بعد قليل . لذلك سنحتاج إلى بوابتي إخراج بمجموع 16 بت سنستخدم منهم 12 لإدارة ال 12 لمبة ويتبقى 4 بتات مـن ال 16 لـن تسـتخدم وستترك للاستخدام المستقبلي . كما ذكرنا سابقا في المثال التوضيحي فإن هناك مفتاح سيقوم المعالج بقراءته دائما وإذا كان هذا المفتاح واحدا (ON) فإن الإشارة تعمل في الحالة العادية ، وأما إذا كان المفتاح صفر ا (OFF) فإن الإشارة ستعمل في الحالة الترددية للون الأصفر flashing . لذلك فإننا سنحتاج إلى بوابة إدخال سنستعمل منها بت واحدة لقراءة حالة هذا المفتاح والباقى لن يستخدم وسيبترك لأى استخدامات مستقبلية . خلاصة القول أننا سنحتاج إلى بوابتي إخراج وبوابـة إدخال . بعد أن قررنا أننا سنحتاج إلى بوابتي إخراج وبوابة إدخال يجب أن نقرر أيضا بأى طريقة من الطرق التي درسناها في الفصل العاشر سنبني هدذه البوابات . لقد قررنا نحن أن نستخدم البوابات القابلـــة للبرمجــة أي الشــربحة 8255A وذلك لسهولة برمجتها وبنائها وكونها شريحة واحدة تحتوي الثلاث بوابات التي نحتاج إليها . شكل (11-8) يبين طريقة توصيل هذه الشريحة على المسارات الثلاثة القادمة من المعالج.

3. يبين شكل (11-8) أيضا كيفية توصيل شريحة الذاكرة EPROM وهي الشريحة 2716 التي سنكتب عليها برنامج التحكم في كل العملية . لقد درسنا في الفصل التاسع طريقة توصيل الذاكرة على المعالج والعملية هنا أبسط بكثير مما شرحنا في الفصل التاسع ، فإنه طالما أن المعالج سيكون متصلا بشريحة ذاكرة واحدة فإن عملية العنونة والتشفير من الممكن أن تكون بسيطة جدا إذا وصلنخط تنشيط الشريحة 2716 وهو الخط SD على خط التحكم MEMR وخط تنشيط خرج الشريحة آآآ بالأرضى مباشرة . في هذه الحالة فإن الشريحة ستعمل وتخرج خرجها مع أي أمر قراءة من الذاكرة ولا حرج في ذلك حيث أنها هي شريحة الذاكرة الوحيدة الموصلة مع المعالج . لاحظ أنه طالما أن ال PROM ستعمل مع أي عنوان يخرجه المعالج فإنه يجب أن نتوقع أنها ستعمل بمجرد توصيل القدرة إليه أو إعادة وضعه RESET فإنه يبدأ التنفيذ من العنوان العنوان طالم 0000H .

4. يمكن توصيل كل بت من بتات الخرج الخارجة من الشريحة 8255 على قاعدة ترانزستور ليعمل كفاصل buffer لإدارة هذه الدايودات حتى تعطى كمية إضاءة أحسن . شكل (11-8) يبين ذلك أيضا .

5. يمكن توصيل خرج البوابات على لمبات 220 فولت للحصول على إنارة قوية ودائرة واقعية عن طريق استخدام عوازل ضوئية opto-couplers .

بالنسبة لجزء البرمجة software فإننا سنفكر فيه بالطريقة التالية :

1. يحتوى شكل (11-9) على جدول به جميع الحالات الممكنة لجميع اللمبات وزمن كل حالة والشفرة أو الرقم المطلوب إخراجه على بوابات الإخسراج للحصول على هذه الحالة . من شكل (11-9) نلاحظ مثلا أنه فى الحالة الأولسي يكون الأخضر الأول مضيئا والأحمر فى جميع الاتجاهات الأخرى مضيئا أيضسا والأصفر فى جميع الاتجاهات مطفأ وسوف يستمر هذا الوضع لمدة 50 ثانية . لاحظ أن المضىء فى الجدول يساوى واحدا والمطفأ يساوى صفرا ، لذلك فسإن هذا الوضع الأول سيكافىء الشفرة 4C على بوابة الإخراج الأولى والشفرة 20 على بوابة الإخراج الأانية . بعد ذلك يضىء الأصفر الأول مع الأخضر الأول مع نفس الوضع السابق لجميع اللمبات الأخرى وذلك كرمن مع نفس الوضع السابق لجميع اللمبات الأخرى وذلك لمدة 10 ثوان وذلك كرمن تحذير بالوقوف بعد الضوء الأخضر . بعد ذلك ستضىء جميع اللمبات الحسراء في جميع الاتجاهات لمدة 5 ثوان كزمن أمان خوفا من السيارات المسرعة التى لا تستطيع التوقف فى خلال الضوء الأصفر . بعد ذلك تكرر هذه الأزمنة لجميع الاتجاهات الأخرى .

لاحظ أن هذه الأزمنة يمكن التحكم فيها بالزيادة والنقصان على حسب الرغبة ، ثم إن تتابع الضوء الأخضر في الاتجاهات المختلفة بمعنى أن أى اتجاه سيسمح له بالمرور وأى اتجاه سيسمح له بعده ، هذه أيضا يمكن التحكم فيها ، إن فكرة البرنامج التي نقترحها هنا (بالطبع فإن كل قارىء ستكون لديه فكرة مختلفة وربما أفضل) تعتمد على ما يلى :

1.  $\frac{1}{2}$  سنخزن في مكان ما في الذاكرة الشفرات المطلوب إخراجها على بوابات الإخراج لكل حالة وكذلك زمن كل حالة بالنتابع من الجدول المبين في شكل (11-9) وليكن ذلك كما يلي:

4C, E100 4C, 02 ستخرج على البوابة الأولى 02, E101 02, E101 05 ق. E102 50, E102 50, E103 4E, E103 4E, E104 02, E104 02, E105 10, E105 10

و هكذا سيحتوى هذا الجدول على 12 بايت .

2. سيكون البرنامج عبارة عن قراءة للشفرتين المقابلتين لكل حالة وإخراجهما على بوابتى الإخراج رقم 00 ورقم 01 ثم الدخول في زمن التأخير المقابل لهذه الحالة.





. قبل الدخول في أي حالة جديدة لابد أن يقرأ المعالج بوابة الإدخال رقم 20 ليعرف إذا كان مفتاح التحكم المقابل للبت رقم صفر يساوى واحد أم صفر ، فإذا كانت هذه البت تساوى واحد فإن البرنامج يسير في سيره الطبيعي كما في الجدول المبين في شكل (11-9) ، وإذا كانت هذه البت تساوى صفرا سيقفز إلى برنامج آخر ينفذ عملية التردد على اللون الأصفر .

شُكُل (11-11) يبين خُريطــة التدفــق ، والبرنــامج مكتوبــا بلغــة الأســمبلى للبروسيسور 8085 سيكون كما يلى : (يلاحظ من هذا البرنامج خلوه من الــبرامج

الفرعية subroutines بالرغم من أفضلية استخدامها هنا في مثل هذه التطبيق ات ولكننا تجنبنا ذلك لسببين أولهما أننا مازلنا لم نشرح البرامج الفرعية حتى الآن في هذا الكتاب وثانيهما أن الدائرة التي بنيناها ليس بها ذاكرة RAM تستخدم كمكدسة stack في حالة استخدام البرامج الفرعية كما سنرى).

| الزمن    | وابة | الد |     |     |           |     |     |      |        |     |     |        |     |            | رقم    |
|----------|------|-----|-----|-----|-----------|-----|-----|------|--------|-----|-----|--------|-----|------------|--------|
| بالثانية | 01   | 00  | G4  | Y4] | <b>R4</b> | G3` | Y31 | 33   | G2`    | Y2I | 32  | G1     | Y1] | <b>R</b> 1 | الحالة |
| 50       | 02   | 4C  | 0   | 0   | 1         | 0   | 0   | 1    | 0      | 0   | 1   | 1      | 0   | 0          | 1      |
| 10       | 02   | 4E  | 0   | 0   | 1         | 0   | 0   | 1    | 0      | 0   | 1   | 1      | 1   | 0          | 2      |
| 5        | 02   | 49  | 0   | 0   | 1         | 0   | 0   | 1    | 0      | 0   | 1   | 0      | 0   | 1          | 3      |
| 50       | 02   | 61  | 0   | 0   | 1         | 0   | 0   | 1    | 1      | 0   | 0   | 0      | 0   | 1          | 4      |
| 10       | 02   | 71  | 0   | 0   | 1         | 0   | 0   | 1    | 1      | 1   | 0   | 0      | 0   | 1          | 5      |
| 5        | 02   | 49  | . 0 | 0   | 1         | 0   | 0   | 1    | 0      | 0   | 1   | 0      | 0   | 1          | 6      |
| 50       | 03   | 09  | 0   | 0   | 1         | 1   | 0   | 0    | 0      | 0   | 1   | 0      | 0   | 1          | 7      |
| 10       | 03   | 89  | 0   | 0   | 1         | 1   | 1   | 0    | 0      | 0   | 1   | 0      | 0   | 1          | 8      |
| 5        | 02   | 49  | 0   | 0   | 1         | 0   | 0   | 1    | 0      | 0   | 1   | 0      | 0   | 1          | 9      |
| 50       | 08   | 49  | _1  | 0   | 0         | 0   | 0   | 1    | 0      | 0   | 1   | 0      | 0   | 1          | 10     |
| 10       | 0C   | 49  | 1   | 1   | 0         | 0   | 0   | 1    | 0      | 0   | 1   | 0      | 0   | 1          | 11     |
| 5        | 02   | 49  | 0   | 0   | 1         | 0   | 0   | 1    | 0      | 0   | 1   | 0      | 0   | 1          | 12     |
| 5        | 02   | 49  |     |     |           |     | زت  | حالا | هذه ال | ار  | تكر | ا يبدأ | هن  | من         | 1      |

شكل (11-9) جدول الحالات المختلفة لإشارة المرور

البواية A أخراج و B أخراج و C إدخال والجميع في الحالة صفر

MVI A,89H ;
OUT 03H ; 8255Å في مسجل التحكم في مسجل التحكم الم

مسجل C عداد يحتوى 12 بايت C عداد يحتوى 12 بايت

LXI H,E100 ; E100 مؤشر للذاكرة ابتداء من HL

READ: IN 02H ; C قراءة البوابة

ANI 01H ; حجب لجميع البتات ما عدا الأولى

قفز عندما PC0=0 لترند اللون الأصفر; PC0=0 لترند اللون الأصفر

إحضار الشفرة الأولى من الذاكرة ; MOV A,M ;

إخراج هذه الشفرة على البوابة A

INXH ;

الحضار الشفرة الثانية من الذاكرة بالصفرة الثانية من الذاكرة (OUT 01 ; B إخراج هذه الشفرة على البوابة

INXH ;



```
MOV A,M
                                              احضار زمن تأخير
                                             هل هذا الزمن =50
          CPI 50H
          JNZ TEN
                                          قفز إذا لم يكن الزمن=50
                                        بداية برنامج تأخير 50 ثانية
         · MVI B,6CH
 LOOP1: MVI D,FFH
 LOOP2: MVI A,FF
 LOOP3: DCR A
          JNZ LOOP3
          DCR D
          JNZ LOOP2
          DCR B
         JNZ LOOP1
          JMP CONTIN ;
    TEN: CPI 10H
                                  هنا التأخير لا يساوى 50 فهل =10
          JNZ FIVE
                                  إقفر إذا لم يكن التأخير = 10
                                    بداية برنامج تأخير 10 ثوان
          MVI B,16H
 LOOP4: MVI D,FFH
 LOOP5: MVI A,FFH
 LOOP6: DCR A
          JNZ LOOP6
          DCR D ;
          JNZ LOOP5
          DCR B
          JNZ LOOP4
          JMP CONTIN
   FIVE: MVI B,0BH
                          هنا التأخير لا يساوي 10 ولكن يساوي 5 ثوان
 LOOP7: MVI D,FFH
                                    بداية برنامج تأخير 5 ثوان
 LOOP8: MVI A,FFH
 LOOP9: DCR A
          JNZ LOOP9
          DCR D
          JNZ LOOP8
          DCR B
          JNZ LOOP7
CONTIN: DCR C
          JZ START
          INX H
          JMP READ
 FLASH: MVI A,92H
                               بداية برنامج تردد الضوء الأصفر
```

OUT 00H الرقمان 92H و 04H يضيئان الأصفر في جميع الأتجاهات MVI A,04H OUT 02H MVI B,D8H بداية تأخير نصف ثانية LOOPA: MVI D,FFH LOOPB: DCR D NOP JNZ LOOPB DCR B JNZ LOOPA اطفاء النور الأصفر في جميع الأتجاهات MVI A,00H OUT 00H OUT 01H MVI B,D8H بداية تأخير نصف ثانية LOOPC: MVI D,FFH LOOPD: DCR D NOP JNZ LOOPD DCR B JNZ LOOPC JMP READ: قفز لقراءة بواية الإدخال PC

سنرى فى فصل البرامج الفرعية كيفية الحصول على أزمنة التأخير باستخدام
 البرامج الفرعية مما سيؤدى إلى اختصار خطوات مثل هذا البرنامج بدرجة كبيرة
 ، ويمكن إعادة كتابة البرنامج بهذا الوضع كتمرين على البرامج الفرعية .

### 6-11 تـمـاريـن

 اعد تصميم كارت الميكروكومبيوتر ، وكذلك البرنامج ، الخاصين بالتحكم في إشارة المرور ولكن مستخدما هذه المرة المعالج Z80 بدلا من المعالج 8085 كما كان في هذا الفصل .

# الفصل الثاني عشر

البرامج الفرعية Subroutines

### 1-12 مـقدمــة

نستطيع القول بأنه عامة عندما تواجهك كمبرمج مشكلة كبيرة ومطاوب منك برمجتها فإن أسهل الطرق لذلك هى أن تقوم بتجزىء أو تكسير هذه المشكلة الكبيرة إلى مشاكل أو مسائل أصغر ثم تقوم ببرمجة هذه المسائل الصغيرة كل على حدة ثم يكون هناك برنامج أساسى يقوم بتجميع أو تتفيذ هذه الأجزاء الصغيرة بالنتابع الذى يحل المسألة أو المشكلة الأساسية . أحد طرق التجزىء هذه هى البرامج الفرعية subroutines . إن استخدام البرامج الفرعية من مميزاتها تسهيل عملية البرمجة واختصار كمية الذاكرة المستخدمة لكتابة شفرات البرنامج كما سنرى فى هذا الفصل .

# 2-12 ما هو البرنامج الفرعى ؟

شكل (1-1) يبين رسما توضيحيا لعلاقة البرنامج الفرعى بالبرنامج الأساسى، نلاحظ من هذا الشكل أن البرنامج الفرعى عبارة عن جـزء مـن برنـامج ، أو برنامج صغير ، يتم النداء عليه للتنفيذ من البرنـامج الأساسى فينفـذ ، وبعـد الانتهاء من تنفيذه تتم العودة إلى البرنامج الأساسى وعند نفس المكان الـذى تـم الخروج منه للبرنامج الفرعى . أى أن طريقة تنفيذ البرنامج الفرعى تشابه وإلـى حد كبير طريقة تنفيذ أو امر القفز ، الاختلاف فقط هو فى عملية العودة إلى نفـس المكان الذى تم القفز منه فى البرنامج الأساسى بعد الانتهاء من تنفيـذ البرنـامج الفرعى ، ويرجع ذلك إلى بعض الخطوات أو الاحتياطات التى يعملـها المعـالج قبل القفز إلى البرنامج الفرعى .

من شكل (12-1) نستطيع أن نتبين الفائدة العظيمة من استخدام البرامج الفرعية وهي توفير الذاكرة المستخدمة لكتابة البرنامج . في الكثير من التطبيقات يكون هناك جزء من البرنامج تكون مضطرا لكتابته أكثر من مرة وكمثال على ذلك جزء البرنامج الذي يعمل زمن التأخير في برنامج إشارات المرور في الفصل السابق . إن مثل هذا الجزء باستخدام البرامج الفرعية يمكن كتابته مرة واحدة فقط وفي كل مرة تكون هناك الحاجة إلى تتفيذه يتم النداء عليه بالأمر CALL فينفذ وبعد الانتهاء من تنفيذه ترجع عملية التنفيذ إلى حيث خرجت من البرنامج الأساسي .

شكل (2-12) يبين خاصية أخرى فى البرامج الفرعية وهى أن أى برنامج فرعى يمكنه النداء على برنامج فرعى آخر ، فمثلا البرنامج الأساسي ينادى البرنامج الفرعى (أ) والبرنامج الفرعى (أ) ينادى البرنامج الفرعى (ب) والبرنامج الفرعى (ب) ينادى البرنامج الفرعى (ج) وهكذا لأى عدد من

التداخلات . هذه العملية تسمى عملية تعشيش nesting للبرامج الفرعية . بعد الانتهاء من تتفيذ آخر برنامج فرعى فى السلسلة وليكن البرنامج الفرعى (ج) فإن المعالج يرجع إلى البرنامج الفرعى (ب) من حيث تم النداء على البرنامج الفرعى (ب) حيث يرجع المعالج إلى البرنامج الفرعى (ب) حيث يرجع المعالج إلى البرنامج الفرعى (أ) من حيث تم النداء على البرنامج الفرعى (ب) ، بعد الانتهاء من تنفيذ البرنامج الفرعى (أ) تتم العودة إلى البرنامج الأساسى من حيث تم النداء على البرنامج الفرعى (أ) .



يجب أن نحذر خطأ أو فخا يمكن أن نقع فيه وهو أن ينادى واحد من السبرامج الفرعية اللاحقة أحد البرامج الفرعية السابقة كأن ينسادى مثلا البرنامج (ج) البرنامج (ب) أو (أ) . في هذه الحالة سيدور المعالج في حلقة لانهائية لا مخرج منها ولن يرجع المعالج أبدا إلى البرنامج الأساسى الذي خرج منه حيث سيظل البرنامج (ج) ينادى على (ب) والبرنامج (ب) ينادى على (ج) إلى ما لا نهاية . هناك الكثير من أو امر النداء على والعودة من البرامج الفرعية . فمنها مسا هو غير مشروط مثل الأمر CALL addr للشريحتين 8085 و 280 بحيث ينتقل النفيذ إلى العنوان addr و أي شرط مثله في ذلك مثل الأمر JMP . وفي

المقابل هناك أمر العودة RET للمعالج 8085 و 280 الذي يكون آخر أمر في البرنامج الفرعي والذي عند تتفيذه تتم العودة دون أي شرط إلى المكان الذي تسم النداء منه . هناك أيضا النداء المشروط على البرامج الفرعية والعودة المشروطة من البرامج الفرعية مثل الأمر CZ addr للمعالج 8085 والذي يعنى نداء عليم برنامج فرعي مشروط بعلم الصفر يساوي واحدا . كما أن هناك أيضا العودة المشروطة بعلم الصفر يساوي واحدا وهو الأمر RZ للمعالج 8085 . راجع الفصل الخاص ببرمجة المعالج الذي تستخدمه للتعرف على جميع أوامر النداء والعودة من البرامج الفرعية .



3-12 كيف يعود المعالج إلى نفس المكان الذي خرج منه ؟

إن السر يكمن فى المكدسة stack ومؤشر المكدسة stack pointer . المكدسة هي جزء مقتطع من الذاكر RAM الملحقة على المعالج لخدمة أغراض النداء والعودة من البرامج الفرعية وأيضا لخدمة أغراض المقاطعة وأغراض أخرى كما سنرى

في فصل آخر . إن أقرب تشبيه للمكدسة هو الجوال (الشوال) الذي نضيف إليسه من فوهته وعندما نأخذ منه فإننا نأخذ من فوهته أيضا ، أي أن آخر ما وضعنسا في الشوال (المكدسة) يكون أول ما نأخذ منها أو Last In First Out وتختصسر في الشوال (المكدسة هو رص الأطباق ، فأنت حينما تسرص الأطباق رأسيا تضيف إلى قمة المكدسة وعندما تريد أخذ طبق فإنك تساخذ آخسر طبسق وضعته على القمة .

وأما مؤشر المكدسة Stack pointer, SP فإنه مسجل مكون من 16 بت محتوياته هي عنوان قمة أو آخر مكان تم التخزين فيه في المكدسة . عندما تكون المكدسة فارغة فإن مؤشر المكدسة يشير إلى قاعها وتكون محتويات ال SP هي عنوان آخر مكان في المكدسة . عند الإضافة إلى المكدسة فإن المؤشر ينقص محتوياته وعند السحب من المكدسة فإن المؤشر تزيد محتوياته بحيث أن الزيادة أو النقص تكون دائما بمقدار 2 لكل عملية سحب أو إضافة كما في شكل (12-3) .



إن الإضافة والسحب من المكدسة تكون دائما على أزواج المسجلات ولا يمكنك بأى حال أن تضيف أو تسحب مسجلا واحدا فقط أو بايت واحدة فقط من أو إلى المكدسة . لذلك فإن مؤشر المكدسة حينما يزيد أو ينقص فإنه يزيد و ينقص بمقدار واحد على بمقدار اثنين ، أى اثنين بايت ، ولا يمكن أن يزيد أو ينقص بمقدار واحد على الإطلاق . شكل (12-4) يبين الخطوات التى يقوم بها المعالج عند تنفيذ أمر النداء على أى برنامج فرعى وهى كالتالى :

1. مؤشر المكدسة SP ينقص decrement بمقدار واحد ، ويخــزن البـايت ذات

القيمة العظمى من عداد البرنامج PC في هذا العنوان .

2. مؤشر المكدسة SP ينقص بمقدار واحد آخر وتخصرن البايت ذات القيمة الصغرى من عداد البرنامج في العنوان الجديد . بذلك يكون قد تم الحفاظ على محتويات عداد البرنامج وهي عنوان الأمر الذي عليه الدور في التنفيذ بعد الأمر CALL في المكدسة .

3. يحمل عداد البرنامج بعنوان أول بايت في البرنامج الفرعي وهـــو العنـوان الموجود في أمر النداء CALL addr ، بذلك ينتقل التنفيذ إلى البرنامج الفرعي . لاحظ من شكل (12-4) أن قاع المكدسة وهي العنوان E21F تكون فارغة دائما وذلك لأن عملية إنقاص مؤشر المكدسة تكون دائما قبل التخزين فيها . في نهايـة تنفيذ البرنامج الفرعي يكون آخر أمر ينفذ هو الأمر RET وعند تنفيذ هذا الأمــو تتم العمليات العكسية للعمليات الموضحة في شكل (4-12) وهي كالتالي :



1. محتويات قمة المكدسة في العنوان E21D وهي الرقم 03 تدفع إلى البايت

ذات القيمة الصغرى من عداد البرنامج وتزداد قيمة محتويات مؤشر المكدسة بمقدار واحد فيصبح E21E .

2. محتويات القمة الجديدة للمكدسة في العنوان E21E وهي الرقم E1 تدفع إلى البايت ذات القيمة العظمي من عداد البرنامج ، وتزداد قيمة محتويات مؤسر المكدسة بمقدار واحد آخر فتصبح E21F وهي قمة المكدسة (أو قاعها) التي كانت موجودة في بداية تنفيذ الأمر CALL E050 .

3. بذلك تصبح محتويات عداد البرنامج هي عنوان الأمر الموجود عند المكان E103 وهو الأمر الذي عليه الدور في التنفيذ في البرنامج الأساسي بعد أمر النداء مباشرة . إن هذه الخطوات قد تختلف اختلافا بسيطا من معالج لآخر ولكن يظل المعنى الأصلي كما هو .

فى حالة البرامج الفرعية المعششة مع بعضها nested مهما كانت درجة تعشيشها فإنه عند كل أمر نداء CALL يتم تخزين عنوان الأمر التسالى للأمر CALL مباشرة (أى الأمر الذى عليه الدور فى التتفيذ) وهكذا إلى أن نصل إلسى آخر برنامج فرعى فى السلسلة حيث سيكون الأمر RET فى آخره هو أول أمر RET يتم تتفيذه ونتيجة له يحمل عداد البرنامج بأول اثنين بايت من قمة المكدسة فيرجع التتفيذ إلى البرنامج الفرعى قبل الأخير وهكذا مع كل أمر RET يسحب عنوان (2 بايت) من قمة المكدسة ويرجع التنفيذ إلى برنامج فرعى سابق إلى أي يصل التنفيذ إلى حيث انتهى من البرنامج الأساسى .

هناك أمر يمكنك من تخزين أى زوج مسجلات في المكدسة وهو الأمر:

PUSH rp

الذى يقوم بتنفيذ أول خطوتين في شكل (-12) ، مع ملاحظة أن محتويات عداد البرنامج لا تتغير هنا على الإطلاق لأنه ليس هناك أى قفز . كذلك فإن الأمر : POP rp

يقوم بالعملية العكسية للأمر PUSH ، أى يسحب اثنين بايت من المكدسة ويضعهم فى زوج المسجلات المذكور فى الأمر POP وينقص محتويات مؤشر المكدسة بمقدار اثنين . هذه العملية تكون مهمة جدا عند خدمة المقاطعة كما سنرى فى فصل قادم وهذان الأمران موجودان لجميع المعالجات التى ندرسها ويمكن مراجعتهما فى قوائم الأوامر .

إن محتويات مؤشر المكدسة التي تشير إلى قاعها أي أول مكان فيها يتم تحديدها عن طريق المبرمج في البرنامج باستخدام الأمر LXI SP,addr حيث يقوم هلذا الأمر بتحميل المسجل SP بالعنوان addr الذي يختاره المبرمج ليكون عنوان قلع المكدسة وذلك في المعالج 8085 ، أو LD SP,addr في حالة المعالج 280 (لاحظ أنه قبل أي تعامل مع المكدسة تكون قمتها هي قاعها أي وهي فارغة).

بذلك نكون قد أنهينا أهم ما يتعلق بالمكدسة ومؤشر المكدسة والبرامج الفرعية وفوائدها وننتقل الآن إلى بعض الأمثلة كتطبيقات على ذلك . لاحظ أن كل ما تم شرحه في هذا الباب يمكن تطبيقه على أى معالج من المعالجات التسى درسناها (والتي سندرسها بخلاف طفيف) ، فقط نكون حذرين عند كتابسة شكل الأمر بالأسمبلي أو شفرته الستعشرية ، ولكن الأساس أو الهيكل العام لفكرة المكدسة والبرامج الفرعية التي شرحناها هي نفسها دائما .

## 4-12 حساب أزمنة التأخير

#### مثال 1-12

لدينا بوابة الإخراج رقم 00 وموصلا عليها ثمانية دايودات أو موحدات ضوئية كل دايود موصل على بت من بتات البوابة . المطلوب إنسارة هذه الدايودات بالنتابع بحيث أن الدايود الأول يضىء وبعده بنصف ثانية يضىء الدايود الثالث و هكذا حتى تصبح كل الدايودات مضيئة ، ثم بعد آخر دايود بنصف ثانية تطفأ جميع الدايودات ثم يبدأ فى الإضاءة من جديد بنفس الطريقة السابقة . اكتب برنامجا يقوم بهذه المهمة مستخدما البرامج الفرعية .

تعتمد فكرة البرنامج على عمل برنامج فرعى التأخير بزمن مقداره نصف ثانية ثم ننادى على هذا البرنامج من البرنامج الأساسى بعد إنارة كل دايود . قبل أن ندخل في تفاصيل البرنامج نريد أن نوضح هنا كيفية الحصول على أي زمن تأخير بأي قيمة . تقوم الفكرة أساسا على عمل حلقة ينفذها المعالج عددا من المرات دون التأثير على أي شيء في البرنامج وبمعلومية عدد مرات تنفيذ هذه الحلقة وعدد الأوامر فيها وزمن تنفيذ كل أمر نستطيع حساب الزمن الكلى لتنفيذ الحلقة . انظر مثلا لهذا البرنامج البسيط:

MVI C,FF; 7

LOOP: DCR C; 4

JNZ LOOP: 10

الرقم الذي على يمين كل أمر هو عدد نبضات التزامن clock التى يأخذها الأمو حتى يتم تنفيذه وهذا العدد موضح في قوائم أوامر كل واحد من المعالجات التي شرحنا طريقة برمجتها في الفصول السابقة . فإذا كان تردد التزامن clock المستخدم هو 2 ميجاهرتز فإن ذلك يعنى أن زمن كل نبضة هو نصف ميكروثانية . لذلك فإن زمن تنفيذ الأمر الأول مثلا سيكون 3.5 ميكروثانية وهكذا . والأمر الثاني سينفذ في 2 ميكروثانية والثالث سينفذ في 5 ميكروثانية وهكذا . في البرنامج السابق نلاحظ أن زمن تنفيذ الحلقة مرة واحدة سيكون (4 +

10)×5.0=7 ميكروثانية ، وهذه الحلقة ستنفذ عددا من المرات مقداره 256 (FF) مرة لذلك فإن مثل هذه الحلقة ستعطى زمن تأخير مقداره 256×7=1792 ميكروثانية ، وأما البرنامج السبابق كله فسيعطى 1792 + 3.5 = 3.5 وأما البرنامج السبابق كله فسيعطى 1792 + 3.5 = 3.5 وأما البرنامج النازمن يكفى كتأخير لما تحتاج فقد انتهيت وإلا فعليك البحث عن طريقة تطيل بها هذا الزمن ، ومن ذلك استخدام زوج من المسجلات بدلا من مسجل واحد كما في البرنامج التالى :

LXI D,FFFF; 10 LOOP: DCX D; 6 MOV A,D; 4 ORA E; 4 JNZ LOOP; 10

هذا البرنامج يقوم بتحميل الزوج DE بالقيمة FFFF (65536) ثم يدخل في حلقة إنقاص بمقدار واحد إلى أن تصل محتويات زوج المسجلات إلى أصفار وعندها تتتهى الحلقة . لاحظ أن الأمر DCX ليس له تأثير على الأعلام لذلك فقد تم نقل محتويات مسجل من الاثنين إلى المركم ثم نفذت عملية OR على المسجلين والتي لن تكون نتيجتها صفرا إلا إذا كانت محتويات كل من المسجلين أصفارا . زمن التأخير الذي سيعطيه هذا البرنامج سيكون :

. ميكرو ثانية 786437=0.5×10+65536×0.5×24 - 0.79= ثانية تقريبا

إذا كان هذا الزمن يفي بما تحتاج إليه من زمن تأخير فقد انتهيت ، وإلا فعليك استخدام الحلقات المعشقة كما في البرنامج التالي :

MVI B,FF; 7
LOOP1: MVI C,FF; 7
LOOP2: DCR C; 4
JNZ LOOP2; 10
DCR B; 4
JNZ LOOP1; 10

زمن تأخير الحلقة الداخلية = 14×0.5×256

= 1792 ميكروثانية تقريبا .

زمن تأخير الحلقة الخارجية= ((7+4+7))×256(1792+0.5)

= 461440 ميكروثانية تقريبا .

زمن التأخير الكلى للبرنامج= 3.5 + 461440

= 461443.5 ميكروثانية .

= 0.46 ثانية تقريبا .

لاحظ أنه وإن كان زمن التأخير الناتج من حلقتين معشقتين أقل من زمن التأخير الناتج من زوج من المسجلات إلا أن الحلقات المعشقة يمكن تعشيقها لأى درجــة

فمثلا في داخل الحاقة LOOP2 يمكن عمل حلقة ثالثة LOOP3 وهكذا للحصول على أزمنة تأخير كبيرة . أحيانا يكون المطلوب أزمنة محددة بقدر الإمكان كما في المثال الذي نحن بصدده الآن حيث المطلوب هو زمن تسأخير مقداره 0.5 ثانية بالضبط . في هذه الحالة يمكن استخدام الأمر NOP في أماكن معينة في حلقات التأخير للضبط الدقيق للأزمنة المطلوبة . مثلا ماذا سيكون الوضع لو أضفنا الأمر NOP داخل الحلقة الداخلية LOOP2 في البرنامج السابق ؟ وإجابة على ذلك فمن المعروف أن الأمر NOP يأخذ 4 نبضات تزامن لذلك سيصبح زمن التأخير الجديد هو 0.59 ثانية تقريبا ، وهذه القيمة أبعد من القيمة المطلوبة ! في هذه الحالة يمكن وضع الأمر NOP في الحلقة الداخلية مع التغيير في القيمة الابتدائية (يفي) بالغرض المطلوب فيمكن تركه في الحلقة الداخلية مع التغيير في الابتدائية في أي من المسجلين B أو C ، ولقد وجدنا أنه بوضع القيمة الابتدائية الكلائية في أي من المسجلين FF فإن زمسن التأخير في هذه الحالة يساوي 499932 ميكروثانية وهي أقرب شيء إلى نصف الثانية . أي أن التعديد البسيط في القيمة النهائية لزمن التأخير ممكن بعدة طرق .

بعد أن رأينا كيفية الحصول على زمن التأخير المطلوب فإن البرنامج التالى ببين عملية الإضاءة التتابعية ، وهذا البرنامج مكتوبا بلغة الأسمبلى للشريحة 8085 . هذا البرنامج كتب بصورة مبسطة جدا ويستطيع كل قارئ أن يأتى ببرنامج آخر يؤدى نفس الهدف وقد يكون أبسط من ذلك . ولقد تعمدنا كتابة البرنامج باستخدام العلامات LABELS حتى نترك للقارئ حرية كتابة البرنامج في أي مكان في الذاكرة يريده . بذلك نكون قد انتهينا من إعطاء القارئ فكرة كافية عن البرامج الفرعية وما بتعلق بها من المكدسة ومؤشر المكدسة .

START: MVI A,01 OUT 00

CALL DELAY

MVI A,03

OUT 00

CALL DELAY

MVI A,07

OUT 00

CALL DELAY

MVI A,0F

OUT 00

CALL DELAY

MVI A,1F

OUT 00

**CALL DELAY** 

MVI A.3F

OUT 00

CALL DELAY

MVI A,7F

OUT 00

CALL DELAY

MVI A,FF

OUT 00

CALL DELAY

MVI A,00

OUT 00

**CALL DELAY** 

JMP START

DELAY: MVI B.DB

LOOP1: MVI C,FF

LOOP2: DCR C

NOP

JNZ LOOP2

DCR B

**INZ LOOP1** 

**RET** 

### 5-12 تسمساريسن

- 1. شرح دور المكدسة مع البرامج الفرعية ؟
- 2. ما هو الفرق بين القفز العادى في أي برنامج والقفز إلى برنامج فرعى ؟
- 3. اشرح دور الأمر RET (أمر العودة من البرامج الفرعية) في ضمان عــودة المعالج إلى نفس المكان الذي خرج منه في البرنامج الأساسي ؟
- 4. لماذا يكون من الضرورى عادة استخدام الأمر PUSH فــــى أول البرنامج
   الفرعى والأمر POP فى آخره ؟
- 5. يحتوى هذا الفصل على بعض البرامج الفرعية للحصول على أزمنة التأخير
   ، فهل يتغير مقدار هذه الأزمنة بتغير التزامن clock المستخدمة ؟
- 6. اكتب برنامجاً فرعيا للحصول على زمن تأخير مقداره 100ميللثانية مع العلم أن التزامن يساوى 2 ميجاهرتز؟
- 7. اكتب برنامجا فرعيا آخر يستخدم البرنامج الفرعى السابق للحصول على زمن تأخير مقداره ثانية واحدة ؟
- 8. اكتب برنامجا فرعيا آخر يستخدم البرنامجين السابقين للحصول على زمــن تأخير مقداره دقيقة واحدة ؟

و. استخدم البرامج الفرعية السابقة في عمل ساعة رقمية تظهر الثواني والدقائق والساعات على مظهرات السبع قطع 7 segment ؟

01. اكتب برنامج التحكم في إشارات المرور في الفصل السابق مستخدما البرامج الفرعية ولاحظ الفرق ؟

11. اكتب برنامج يحسب قيمة X التالية:

X = 5! + 8! + 9!

حيث ! تمثل مضروب الرقم .

12. اكتب برنامج يحسب قيمة X التالية:

 $X=5^5+8^4+9^3$ 

# الفصل الثالث عشر

المقاطعة

Interrupt

### 1-13 مقدمة

ثقد رأينا فى الفصول السابقة كيفية مواجهة المعالج مع الأجهزة المحيطة سواء كانت ذاكرة أو بوابات إدخال وإخراج . فى العادة يقوم المبرمج بكتابة برنامج على أساسه يقوم المعالج بخدمة هذه الأجهزة المحيطة . هذاك طريقتان يمكن للمعالج أن يخدم بهما هذه الأجهزة المحيطة وهما :

1. الطريقة الأولى سنسميها "خدمة طرق الأبواب" التي عرفت في المراجع الإنجليزية بكلمة polling والتي لها نفس المعنى كما سنرى ولكن الترجمة ليست حرفية .

2. الطريقة الثانية هي طريقة المقاطعة interrupt وهي الطريقة التي سنشرحها بالتفصيل في هذا الفصل ، ولكن لا مانع من القاء نظرة سريعة على الطريقين قد الأولى حتى يختار القارىء أي الطريقين يحب أن يستخدم .

# 2-13 طريقة طرق الأبواب لخدمة الأجهزة المحيطة Polling service

تعتمد هذه الطريقة على أن المعالج يقوم بطرق أبواب جميع الأجهزة المحيطة بالتتابع ويسأل كل منها هل تريد خدمة أقوم بأدائها ؟ فإذا كانت إجابة الجهاز بنعم فإن المعالج يقوم بتنفيذ هذه الخدمة له وفى الحال دون أى إنتظار ، أما إذا كانت إجابة الجهاز بالنفى فإن المعالج ينتقل إلى الجهاز التالى له ويسأله نفس السوال ، وهكذا إلى أن يصل المعالج إلى آخر جهاز فإما أن يخدمه أو لا على حسب إجابته . بعد آخر جهاز يرجع المعالج إلى أول جهاز ويعيد الكرة من جديد إلى مالانهاية . أى أن الوظيفة الوحيدة للمعالج في هذه الحالة هلى المدوران إلى مالانهاية على الأجهزة المحيطة وتقديم الخدمة لمن يجيبه . شكل (13-1) يبين مخطط سير لوظيفة المعالج في هذه الحالة . لقد استخدمنا هذه الطريقة إلى حد ما في مثال إشارات المرور الذي سبق شرحه في الفصل الثاني عشر حيث كان المعالج دائما يسأل بوابة الإدخال ، أي يقرأها ، فإذا كانت واحددا يقوم بتنفيذ برنامج آخر وبعد الانتهاء من أي من البرنامج معين ، وإذا كانت صفرا يقوم بتنفيذ برنامج آخر وبعد الانتهاء من أي من البرنامجين يرجع ويقرأ بوابة الإدخال مرة ثانية وهكذا إلى مالانهاية .

إن من مميزات طريقة طرق الأبواب لخدمة الأجهزة المحيطة أنها سهلة البرمجة ولا تحتاج إلى الكثير من التجهيزات hardwar . وإن من عيوبها أن المعالج يكون مخصصا لوظيفة خدمة هذه الأجهزة ولا يستطيع الفكاك منها وأنت كمـــبرمج لا تستطيع عادة الاستفادة منه في أي أغراض أخــرى ، وبـالذات إذا كـان عــدد

الأجهزة التى يقوم المعالج بالمرور عليها قليلا فإن ذلك يعتبر إهدارا لفعالية المعالج . أما إذا كان عدد الأجهزة التى يقوم المعالج بخدمتها بهذه الطريقة كبيرا فإن المعالج قد يتأخر على بعض الأجهزة التى تحتاج لخدمته على فترات متقاربة لأن عليها الإنتظار لحين أن يجىء دورها ، كما أنها ليس من حقها أن تقاطع المعالج وتطلب الخدمة الفورية فى حالات الضرورة ، وكما نعلم فإن هناك الكثير من المواقف التى تستلزم الخدمة من المعالج فورا كضرب جرس إنذار مثلا عند حدوث أى طارىء فى أى نظام تحكم مثل إنقطاع الكهرباء أو حريق أو إرتفاع زائد فى ضغط غاز وغيرها الكثير ، لذلك فإن المعالج يقدم للمبرمج نوعا آخسر من الخدمة وهى المقاطعة التى سنتكلم عنها بالتفصيل فى الجزء القادم .



## 3-13 المقاطعة Interrupt

في نظام خدمة الأجهزة الخارجية عن طريق المقاطعة لا يذهب المعالج إلى الأجهزة ويطرق بابها ليعرض عليها خدماته فإن أرادت أعطى وإن أبت يذهب إلى جهاز آخر ، لا ، بل إن المعالج هنا يكون عادة مشغولا في تتفيين برنامج معين وعادة ما يكون هذا البرنامج لا نهائي فإذا احتاج أحد الأجهزة لخدمة مين المعالج فإنه يقاطعه ويطلب منه الخدمة فيقوم المعالج بتتفيذ هذه الخدمة للجهاز المقاطع وبعد الانتهاء من هذه الخدمة يعود المعالج لتنفيذ البرنامج الأساسي مين حيث انتهى قبل المقاطعة . إن ذلك تماما مثلما أنك تكون واقفا مع أحد زملائيك تتحدثان ، ثم يجيء آخر ويقاطعكما ليسأل عن موعد محاضرة المعالجات ، في حديثه الأول . إن البرنامج الذي يقوم المعالج بتتفيذه عند المقاطعة يسمى برنامج خدمة المقاطعة .

من مميزات هذه الطريقة أن الأجهزة المقاطعة تستطيع مقاطعة المعالج فـــى أى وقت تريد وليس عليها الإنتظار إلى دورها مثل الطريقة السابقة ، وإذا تصــادف وتمت المقاطعة فى نفس الوقت من أكثر من جهاز فإن المعالج يخدمها حسب أولويات تحدد له من قبل المستخدم مسبقا ، فكيف يتم ذلك ؟ فى أتثاء انشخال المعالج فى تتفيذ برنامج خدمة مقاطعة معينة ، هل يسـتطيع جهاز أخر أن يقاطعه؟ كيف نكتب برنامج خدمة المقاطعة ؟ وكيف يرجع المعالج إلــى نفس مكانه فى البرنامج الأساسى بعد إنتهاء خدمة المقاطعة ؟ كل هذه الأسئلة وأكــثر سنجيب عليها من خلال دراستنا للأجزاء القادمة وبعد دراستنا لتفاصيل مقاطعــة كل معالج من المعالجات التى درسناها .

إن المقاطعة تكون عادة عن طريق إشارة يرسلها الجهاز المقاطع إلى المعالج على أحد أطرافه المخصصة لذلك وعندما يكتشف المعالج هذه الإشارة فإنه يقوم بتنفيذ برنامج خدمة المقاطعة وذلك يرجع لأن المعالج يقوم بقراءة جميع أطراف المقاطعة وإختبارها قبل الدخول في تنفيذ أي أمر وإليك بعض الأمثلسة التسي تستخدم فيها المقاطعة:

- الأجهزة الخارجية مثل الطابعة ولوحة المفاتيح يمكنها أن تقاطع المعالج وترسل أو تستقبل أي معلومات .
- يمكن في أي وقت مقاطعة أي برنامج يتم تتفيذه إذا كان هذا البرنامج ينفذ بطريقة خطأ .
- يمكن العمليات الصناعية التي يتم مراقبتها باستخدام المعالج أن تقاطعة في أي لحظة طواريء تحدث للعملية الصناعية .

عند إعطاء إشارة المقاطعة لأى معالج من المعالجات التى نقوم بدر استها يحدث الآتى مع بعض الإختلافات البسيطة من معالج لآخر سنشير إليها فى موضعها . 1. الأمر الحالى يتم إكمال تنفيذه من قبل المعالج .

2. عنوان الأمر الذى عليه الدور فى النتفيذ (محتويات عداد البرنامج) تخزن فى المكدسة Stack حتى يمكن العودة إليه عند الانتهاء من خدمة المقاطعة . كما يتم تخزين محتويات أى مسجل يخشى من تغيير محتوياته فى أثناء خدمة المقاطعة ويتم ذلك عن طريق المبرمج .

3. كل إشارة مقاطعة لها عنوان خاص مصاحب لها كما سنرى ، يتم وضع هذا العنوان في عداد البرنامج (عن طريق المعالج) حيث يقفز المعالج إلى هذا العنوان ويبدأ في تتفيذ البرنامج الذي يكون هذا هو عنوان أول أمر فيه ويسمى هذا البرنامج ببرنامج خدمة المقاطعة وتتم كتابته عن طريق المستخدم.

4. بعد الانتهاء من برنامج خدمة المقاطعة يعود المعالج إلى البرنامج الأصلي ليستأنف تنفيذه من نفس مكان المقاطعة بالاستعانة بالعنوان الذى تم تخزينه في المكدسة كما في الخطوة رقم 2.

إن الجهاز المقاطع في الكثير من الأحيان وبعد إعطاء إشارة المقاطعة وقبول المعالج لها والبدء في برنامج الخدمة فإن الباب يظل مفتوحا للأجهزة الأخرى للمقاطعة مما قد ينشأ عنه موقف يجب الحرص منه . لو أن المعالج بدأ في خدمة المقاطعة وما زال طرف المقاطعة الموصل على الجهاز المقاطع فعالا فإن المعالج سيبدأ في خدمة نفس المقاطعة من جديد على الرغم من أنه لم ينته من الخدمة السابقة ، وبمجرد أن يبدأ في خدمة المقاطعة من جديد للمرة الثانية ومنا زال خط المقاطعة فعالا من قبل الجهاز المقاطعة من المعالج سيبدأ في الخدمة من جديد أيضا ، وهكذا فإن المعالج سيدخل في حلقة لا نهائية لن يخرج منها دون أن ينفذ برنامج خدمة المقاطعة . لتجنب هذا الموقف يجب على المبرمج أن يضع أمرا معينا في بداية برنامج خدمة المقاطعة يمنع المعالج من خدمة أي مقاطعة إلى أن ينتهي من الخدمة الحالية التي دخل فيها . إن هذه العملية لها تقاصيل ستختلف من معالج إلى آخر لذلك سنرجىء الكلام عنها الأن .

# 13-4 مقاطعة المعالج 8085

شكل (13-2) يبين جدو لا لجميع أطراف المقاطعة الخاصة بالشريحة 8085 وعنوان المكان الذي يتم القفز إليه عند إعطاء إشارة المقاطعة على هذا الطرف وكذلك الأولوية الخاصة بكل طرف من أطراف المقاطعة وكيفية إعطاء هذه الإشارة على كل طرف . كما نلاحظ من هذا الشكل فإن الطرف RST5.5 له أعلى أولوية ثم يليه الطرف RST5.5 ثم يكون

الطرف INTR له أقل أولوية . إن كلمة أولوية هنا تعنى أنه إذا جاءت إشـــارتان على خطين مختلفين من خطوط المقاطعة في نفس الوقت تماما فإن الإشارة التــي على الخط ذي الأولوية الأعلى هي التي تؤخذ في الاعتبار أما الإشارة الأخــري فتهمل .

| طرف المقاطعة | الأولوية | العنوان الذى<br>يتم القفز إليه | كيفية إعطاء الإشارة على الطرف                                  |
|--------------|----------|--------------------------------|----------------------------------------------------------------|
| TRAP         | 1        | 0024H                          | الحافة صفر إلى واحد ويبقى<br>واحد الى أن تقبل المقاطعة         |
| RST7.5       | 2        | 003CH                          | الحافة صفر إلى واحد حيث يتــــــم<br>مسك هذا الواحد في المعالج |
| RST6.5       | 3        | 0034H                          | يبقى واحد إلى أن تقبل المقاطعة                                 |
| RST5.5       | 4        | 002CH                          | <del></del>                                                    |
| INTR         | 5        | له تفاصیل                      | يبقى واحد إلى أن تقبل المقاطعة                                 |

شكل (13-2) أطراف المقاطعة للشريحة 8085 وأولوياتها وعناوين القفز الخاصة بكل منها وكيفية إعطاء كل إشارة على هذه الأطراف

### 1-4-13 الخطوط RST5.5, RST6.5, RST7.5 الخطوط

بالنسبة للمعالج8085 هناك بعض الأوامر المتعلقة بالمقاطعة والتي يجب معرفتها أو لا ومن هذه الأوامر ما يلي :

- الأمر EI ومعناه تنشيط المقاطعة Enable Interrupt في داخل شريحة المعالج قلابا flip flop يسمى قلاب تنشيط المقاطعة ، RST5.5, RST6.5, RST7.5, أي أن أي إشارة مقاطعة على جميع الخطوط (TRAP بالقلاب يساوى واحدا. (INTR) ما عدا الخط TRAP لن تنفذ إلا إذا كان خرج هذا القلاب يساوى واحدا. لذلك فإن هذا القلاب يعتبر بمثابة مفتاح مركب على التوالي مع هذه الخطوط مجتمعه يتم فتحه (ON) بالأمر EI. شكل (13-3) يبين وضع هذا المفتاح بالنسبة لهذه الخطوط.
- الأمر DI ومعناه إخمد أو امنع أو لا تقبل المقاطعة على الأمر Dissable وكما نرى فإن تأثيره على قلاب تتشيط المقاطعة يكون تماما عكس تأثير الأمر DI . يستخدم الأمر DI في حجب أو إخماد المقاطعة في بعض أجزاء من البرنامج ومن أهمها برامج خدمة المقاطعة نفسها ، لذلك فإنه يجب على المبرمج أن يضع الأمر DI في بداية أي برنامج لخدمة المقاطعة لحماية هذه المقاطعة من نفسها ومن الدخول في الحلقة اللانهائية التي ذكرناها منذ قليل . في نهاية برنامج خدمة المقاطعة من جديد .

• مثلما أن هناك مفتاحا عموميا (علم المقاطعة) لجميع أطراف المقاطعة ما عدا الخط TRAP يمكن تتشيطها به أو حجبها به عن طريق الأمرين EI و TRAP هناك لكل واحد من الخطوط RST7.5 و RST6.5 و RST7.5 مفتاحا خاصا به هناك لكل واحد من الخطوط أو حجبه ، كما أن الخط RST7.5 له مفتاح أو قسلاب يمكن به تتشيط هذا الخط أو حجبه ، كما أن الخط ST7.5 له مفتاح أو قسلاب آخر إضافي خاص به هو فقط يمكن منه حجب المقاطعة عليه حتى لو مرت من خلال المفتاح الأول وهذه ميزة للخط RST7.5 عن باقى الخطوط الأخرى . انظر لهذه القلابات أو المفاتيح في شكل (1-3) . هذه المفاتيح يمكن تتشيطها أو حجبها عن طريق الأمر Set Interrupt والذي يعنى "ضع أقنعة المقاطعة" Masks



إن هذا الأمر عند تنفيذه يتم تنشيط أو حجب أو وضع قناع على أى خط من هذه الخطوط على ضوء شفرة توضع فى مسجل التراكم قبل هذا الأمر مباشرة . شكل (13-4) يبين علاقة بتات مسجل التراكم مع هذه المفاتيح . نلاحظ من هذا الشكل مثلا أن قناع الخط RST5.5 هو البت رقم 0 فإذا كانت هذه البت تساوى صفرا فإن الخط RST5.5 يكون نشطا أى غير مقنع أو غير محجوب ، أما إذا كانت هذه البت تساوى واحدا فإن ذلك يعنى أن الخط RST5.5 يكون مقنعا أو محجوبا .



نفس الشيء يمكن أن يقال عن الخطوط RST6.5 و RST7.5 وبتاتها المقابلة رقمي واحد وإثنين . البت D4 تمثل المفتاح الإضافي الخاص بالخط RST7.5 فإذا كانت هذه البت تساوى واحد فإن المقاطعه RST7.5 تكون مقنعة أو محجوبة . شكل (3-1) يبين رسما توضيحيا لمفاتيح الأقنعة لكل خط مقاطعة وكيفية التحكم بهذه المفاتيح وعلاقتها ببعضها .

#### مثال 1-13

اكتب الأمر الذي ينشـــط المقاطعــة RST5.5 و RST7.5 ويحجــب المقاطعــة RST6.5 مطالما أن RST7.5 نشط ، إذن D=D0 وكذلك طالما أن RST5.5 نشط إذن D=D0 وكذلك طالما أن RST5.5 نشط إذن D=D2 وأيضا D4=0 وطالمــا أن RST6.5 مقنـع أو محجــوب إذن D1=1 وللحصول على ذلك الوضع لابد وأن تكون 1=D3 . وأما D6 فلابــد أن تكــون صفرا لأننا لسنا في حالة إخراج بيانات تتابعية وعلى ذلك فإن البت D7 لا يــهم في هذه الحالة أن تكون صفرا أو واحدا طالما أن D=D6 . كذلك فإن D5 لا يــهم أن تكون صفرا أو واحد . وعلى ذلك فإن محتويات المركم ستكون كما يلى :

D7 D6 D5 D4 D3 D2 D1 D0 0 0 0 0 1 0 1 0 = 0AH

ولكي يتم ذلك ننفذ الأمرين التاليين:

MVI A,0AH SIM

#### مثال 13-2

تخيل أن هناك جهاز إستقبال للبيانات النتابعية موصلا على الطرف SOD (طرف رقم 4) للشريحة 8085 ، والمطلوب هو إرسال 0 إلى هذا الجهاز كتتشيط لكى يبدأ في الإستقبال وذلك دون التأثير على حالة أطراف المقاطعة التي تم تجهيزها في المثال الماضي .

من شكل (13. 2) نجد أنه حتى نترك أقنعة المقاطعة على البتات D0,D1,D2,D4 وحتى ننشط البت 70 كبت D7 كبت للإخراج التتابعي فإن 1=D6 ، ونضع 0=D7 لكي نخرجه على الطرف SOD . لاحظ أن البتات D0,D1,D2,D4 في هذه الحالة لا يهم أن تكون صفرا أو واحدا وسنفترضها أصفارا ، وعلى ذلك تكون محتويات المركم كالتالي :

D7 D6 D5 D4 D3 D2 D1 D0

0 1 0 0 0 0 0 0 =40H

ولكى يتم ذلك ننفذ الأمرين التالبين:

MVI A,40H SIM لاحظ أن الخط TRAP لا يتأثر بأى شيء من ذلك .

يمكن عمل مقارنة بين خطوط المقاطعة RST5.5 و RST6.5 و RST7.5 وثلاثـة خطوط تليفونات تخرج من سنترال في شركة معينة كالتالي: تخيل أن واحدا من هذه الخطوط هو تليفون رئيس الشركة وهو الخط RST7.5 والخط الثاني هو خط نائب الرئيس وهو الخط RST6.5 وأما الخط الثالث فهو خط مدير شئون الأفراد وهو الخط RST5.5 . هناك مكتب استقبال يرد على التايفونات القادمة للأشخاص الثلاثة ويوجهها إلى الشخص المطلوب. في وقت الدوام (العمل) يعمل سينتر ال الشركة ويكون نشطا وفي غير وقت الدوام لا يعمل هذا السنترال ، ذلك يكافيء تماما تتشيط هذه الخطوط بالأمر EI وحجبها أو إخمادها بالخط DI . كل واحد من الأشخاص الثلاثة (الرئيس ونائبه ومدير شئون الأفراد) يترك خــبرا فــي مكتب الاستقبال عما إذا كان يريد استقبال مكالمات أم لا ، ذلك يكافيء وضع الشفرة المناسبة في البتات 0 إلى 2 في مسجل التراكم ثـم تتفيــذ الأمــر SIM . إفترض أن السنترال يعمل والاستقبال موجود أيضا فإنه سيرد على المكالمات ويوصلها أو يمنعها عن الأشخاص الثلاثة وذلك على حسب الأوامر التي تركوها عنده ، إن ذلك يكافيء تماما كون البت 3 تساوى واحدا في الشفرة الموجودة في المسجل A . أحيانا يكون السنترال يعمل ولكن الاستقبال مشغول ، في هذه الحالة كل المكالمات القادمة ستوصل أو لا توصل على حسب آخر قائمة أوامر من الأشخاص الثلاثة دون أي اعتبار لأي تغيير يريده أي واحد منهم وهذا يكـافيء حالة المسجل A قبل آخر مرة ينفذ فيها الأمر SIM وتكون البت 3 تساوى صفرا في هذه الحالة . هناك ميزة فريدة للرئيس وهي أن عنده مفتاحا خاصا به بحيـــث عندما يكون هذا المفتاح ON ترد ماكينة إجابة ذاتية تقول "المدير مشعول الأن من فضلك اتصل مرة أخرى" . هذا يكافيء تماما البت 4 التي عندما تكون صفر ا فإن الخط RST7.5 يكون فعالا وإذا كانت واحدا فإن هذا الخط يكــون مقنعــا أو محجوبا .

هناك الأمر RIM الذي يتكون من بايت واحدة والذي يقوم تقريبا بالعملية العكسية للأمر SIM الأمر SIM حيث يقوم بتحميل المسجل A بثمانية بتات توضح حالة أقنعة المقاطعة . لذلك فإن هذا الأمر معناه "اقرأ أقنعة المقاطعة المقاطعة الأمر Masks . في حالة قراءة أقنعة المقاطعة بالأمر RIM في المسجل A في حالة قراءة أقنعة المقاطعة بالأمر RIM في أن بتات المسجل تترجم محتوياتها كما في شكل (13-5) حيث الثلاثة بت الأولى 0 إلى 2 هي حالة أقنعة خطوط المقاطعة 5.75 RS و 8575.5 و RST7.5 كما تم تسجيلها باستخدام الأمر SIM مسبقا . البت الثالثة تبين حالة قلاب أو علم المقاطعة الدي رأينا كيف نتحكم فيه بالأمرين EI و DI . افترض أن المعالج يقوم الآن بخدمة مقاطعة للخط RST6.5 و RST6.5 في اثناء ذلك افترض أن الخط RST6.5 في حالة إنتظار المقاطعة ، ماذا سيفعل المعالج ؟ إن المعالج يضع الخط RST6.5 في حالة إنتظار

Pending إلى حين الانتهاء من خدمة المقاطعة RST7.5 . في هذه الحالة يستطيع المبرمج كتابة بعض الأوامر في آخر برنامج خدمة مقاطعة الطرف RST7.5 . ويجعل المعالج يذهب إلى خدمة المقاطعة RST6.5 بسدلا من العسودة للبرنسامج الأساسي . البت رقم 5 في مسجل التراكم تعكس هذه الحالة ، فإذا كان الطسرف RST6.5 في حالة انتظار فإن هذه البت تكون واحدا وتكون صفرا في غير ذلك . البت رقم 4 تمثل الانتظار لطرف المقاطعة RST5.5 والبت رقم 6 تمثل الانتظار لطرف المقاطعة RST5.5 والبت رقم 6 تمثل الانتظار في أند المؤلفة تتابعيا إن وجدت حيث سنترك الحديث عسن الإدخال والإخراج النتابعي للبيانات الآن .



شكل (13-6) يبين مثالاً على إختبار المقاطعة RST6.5 في نهاية برنامج مقاطعة الخط RST7.5 بحيث إذا كانت في حالة انتظار يذهب المعالج لخدمتها قبل الرجوع للبرنامج الأساسي .

نهاية برنامج خدمة مقاطعة الخط RST7.5

قراءة أقنعة المقاطعة; RIM

تخزين معلومات الأقنعة في المسجل B,A ; B لمسجل ANI 20H ; RST6.5 إذا كان الخط

في الإنتظار , أي البت خمسة من A تساوي و احد :

JNZ NEXT

RST6.5 لا ينتظر , نشط المقاطعة ;

عودة للبرنامج الأساسي ; RET

NEXT: MOV A,B ; A أعد حالة الأقنعة للمسجل

تتشيط المقاطعة RST6.5 قد تكون مقنعة ; ANI ODH ORI O8H وتشيط البتات اللي 2 قد تكون خاملة ;

سجل الصورة الجديدة للأقنعة ; SIM

إقفز إلى برنامج خدمة المقاطعة RST6.5 ; RST6.5

شكل (13-6) خدمة RST6.5 من برنامج خدمة RST7.5

#### <u>مثال 13–3</u>

: A وجدت المحتويات التالية في المسجل RIM وجدت المحتويات التالية في المسجل D7 D6 D5 D4 D3 D2 D1 D0

 $0 \quad 1 \quad 0 \quad 0 \quad 1 \quad 0 \quad 0 \quad 1 = 49H$ 

إن ذلك يعنى أن المقاطعة RST5.5 هـى المحجوبة (D0=1) وأما المقاطعة RST6.5 و RST6.5 و RST7.5 فنشيطان (D2D1=00) ، كذلك فإن علم المقاطعة IF نشيط أي أن الأمر EI مازال سارى المفعول ، والمقاطعة RST7.5 فقط هي التي فـــى حالة انتظار (D6D5D4=100) كما أن هناك 0 قادم من الطرف D7=0) .

#### مثال 13-4

المطلوب عمل مؤقت timer لزمن مقداره دقيقة واحدة باستخدام التردد 60 هرتر الناتج من خط القدرة. هذا المؤقت يعرض الزمن على 3 خانات واحدة للدقائق وإثنتان للثواني بحيث تعرض خانة الدقائق واحدا (أي دقيقة واحدة) ثم يبدأ العد

التصاعدى للثوانى إلى أن تصل إلى 60 فترجع إلى الصفر مرة أخرى وتستمر خانة الدقائق تعرض و احدا و تبدأ الثوانى فى العد التصاعدى ، و هكذا . شكل (13-7) يبين الدائرة المستخدمة لهذا الغرض و شكل (13-8) يبين البرنامج المقترح لذلك . تعتمد الدائرة المستخدمة على تحويل جهد القدرة من 110 فولت المقترح لذلك . تعتمد الدائرة المستخدمة على تحويل جهد القدرة من 110 فولت الى 6 فولت باستخدام محول خافض للجهد ثم تقسيم هذا الجهد و إدخاله على مقارن 1 1 TTL . تستخدم هذه الموجة لعمل إثارة rigger للشريحة 1412 التي تخرج نبضة للتارج على التحكم في عرضها باستخدام المكثف C والمقاومة R . هذه النبضة الخارجة من الشريحة 14121 توصل على الطرف RST6.5 حيث ستعطى 60 نبضة مقاطعة في الثانية الواحدة على هذا الطرف .

لكى نفهم البرنامج سنسير معه بالخطوات التالية :



أولا: عندما ستجىء نبضة مقاطعة على الطرف RST6.5 من الشريحة 74121 فإن المعالج سيقفز إلى العنوان 0034H أوضحنا في شكل ( $^{2}$ -2). هذا العنوان يقع في أول صفحة من الذاكرة حيث كل صفحة من الذاكرة تحتوى 256 بايت (FFH) وعادة ما يكون هذا الجزء من الذاكرة مشغو لا ب EPROM تحتوى بعض البرامج الخاصة بتشغيل الميكروكومبيوتر. إذا كان الأمسر كذلك فإن مبرمج ال EPROM عادة يسجل في مثل هذه الأماكن أمر قفز إلى مكان أخسر بحيث يكون هذا المكان في ال

الذى تتدرب عليه وتعرف منه أمر القفز الموجود عند العنوان 0034 أين يقفز فى ال RAM . سنفترض أن هذا العنوان هو أى عنوان وسنعطيه الرمز xxxx حيث سنكتب عند هذا العنوان برنامج خدمة المقاطعة .

```
0034 JMP xxxx
      هذا هو البرنامج الأساسي Main program ------
                       تحديد بداية المكدسة بالعنوان STCK
LXI SP, STCK
                     الرقم 1D ينشط المقاطعة RST6.5 ويخمد الباقي ;
MVI A,1DH
                    تنشيط المقاطعة RST6.5
SIM
                        تصفير المسجلين C, B للدقائق والثواني ;
LXI B,0000H
                   الرقم 3CH يعادل 60 وهي عدد الثواني ;
MVI D,3CH
     تتشيط المقاطعة قبل الدخول في برنامج إظهار الأرقام :
DSPLY: MOV A,B
                           إظهار الدقائق على البوابة 00;
OUT 00
MOV A,C
                           اظهار الثواني على البوابة 01;
OUT 01
JMP DSPLY
xxxx: DCR D
                   بداية برنامج خدمة المقاطعة في ال RAM ;
                  تتشيط المقاطعة قبل الرجوع للبرنامج الأساسي ;
ΕI
                عودة طالما أن عدد المقاطعات لم يصل إلى 60;
RNZ
                     أخماد المقاطعة إذا وصل العدد إلى 60 مقاطعة ;
DI
                        تحميل المسجل D بالرقم 60 ثانية مرة أخرى;
MVI D,3CH
INC C
                        ز د الثواني بمقدار واحد ;
MOV A,C
DAA
                    وضع الثواني في الصورة العشرية;
MOV C,A
CPI 60
                       هل وصل عدد الثواني إلى 60 ثانية:
ΕI
                   تنشيط المقاطعة قبل العودة للبرنامج الأساسي ;
                عودة طالما لم نصل إلى 60 ثانية;
RNZ
                     إخماد المقاطعة إذا وصل عدد الثواني إلى 60 ثانية ;
DI
MVI C,00
                         تصفير عداد الثواني ;
MVI B,01
                        حمل المسجل B بدقيقة (زمن التأخير);
EI:
                     تنشيط المقاطعة قبل العودة:
عودة للبرنامج الأصلى : RET ;
           شكل (13-8) برنامج المؤقت باستخدام المقاطعة
```

ثانيا: أهم جزء في البرنامج الأساسي هو حلقة لا نهائية تخرج على بوابتي الإخراج 00 و 01 قيمة الثواني التي تتغير كل ثانية وقيمة الدقائق التي هي واحد باستمرار والتي يمكن التحكم فيها من البرنامج ، البوابات غير مبينة في شكل (7-1-) للتبسيط فقط .

ثُالثًا: مع كل نبضة مقاطعة على الطرف RST6.5 سيقفز المعالج مــن الحلقـة اللانهائية إلى العنوان 0034 ومنه إلى العنوان xxxx حيث سيبدأ من هناك تنفيــذ برنامج خدمة المقاطعة.

رابعا: في برنامج خدمة المقاطعة سيكون هناك عداد تزداد محتويات له بمقدار واحد مع كل نبضة مقاطعة بحيث أنه طالما أن محتويات هذا العداد لم تصل إلى 60 فإن المعالج يرجع إلى البرنامج الأساسي في الحلقة الانهائية حيث يستأنف عمله كما في الخطوة (ثانيا).

خامسا: مع تكرار المقاطعة سيصل العداد في برنامج الخدمة إلى 60 حيث عندها يقوم برنامج الخدمة بتعديل قراءة الثواني بزيادتها بمقدار ثانية واحدة .

سمادسا: إذا وصل عدد الثواني إلى 60 يكون قد مضى دقيقة ، عندها يرجع عداد الثواني إلى الصفر لتبدأ العملية من جديد .

شكل (2-13) يبين كيفية استقبال المعالج لنبضات المقاطعة على الخطوط RST5.5, RST6.5, RST7.5 حيث نلاحظ من هذا الشكل أنه بالنسبة للخط RST5.5, RST6.5, RST7.5 بالذات يكفى أن تصعد النبضة من صفر low إلى واحد high لكى يستقبل المعالج هذه الإشارة وذلك لوجود ماسك في مدخل هذا الخط الخطان RST5.5, RST6.5 لابد أن تبقيا واحدا high إلى أن يقبلها المعالج وإلا لو أنها نزلت إلى الصفر low قبل أن يقبلها المعالج فإن هذه المقاطعة لن تخدم بواسطة المعالج لعدم وجود ماسك في مدخل كل خط من هذه الخطوط.

#### 2-4-13 الخط TRAP

خط المقاطعة TRAP يتميز بميزة خاصة عن الخطوط السابقة وهي أن هذا الخط لا يمكن حجبه أو إخفاؤه أو تعطيله بأى واحد من الأوامر السابقه وهي SIM أو DI وكذلك لا يحتاج للأمر EI لتشيطه . لذلك فإن هذا الخط يسمى SIM أو Nonmakable interrupt أو المقاطعة التي لا يمكن حجبها . عادة يستخدم هذا الخط كما أشرنا سابقا في عمليات المقاطعة الخطيرة مثل الحريق أو إنقطاع التيار الكهربي أو غير ذلك من العمليات الصناعية الخطيرة . هذا الخط كما هو موضح في شكلي (13-2 و 13-3) لابد وأن يرتفع من صفر إلى واحد ويستمر واحدا high إلى أن يقبله المعالج وإذا نزل إلى الصفر قبل أن يقبله المعالج فان يكون له أي تأثير .

#### 3-4-13 الخط INTR

آخر خط من خطوط المقاطعة في المعالج 8085 هو الخط INTR . هــذا الخــط يعتبر من خطوط المقاطعة التي يمكن إخفاؤها أو وضع قنــاع عليـها أي أنـها maskable عن طريق الأمر DI ولا تقبل أو يتم خدمتها إلا إذا كان علم المقاطعة IF فعالا عن طريق الأمر EI كما في شكل (3-1) . سنحاول فهم ما يقوم بــه المعالج وما يحتاج إليه من دوائر خارجية من خلال تتبعنا الخطوات التي يقوم بها المعالج عندما يشعر بأن الخط INTR واحد high وهذه الخطوات كما يلي :

الخطوة الأولى: فى أثناء تنفيذ كل أمر من أوامر أى برنـامج يقوم المعالج باختبار الخط INTR هل يساوى واحدا أم صفرا، وذلك من تلقاء نفسه وتبعا لتركيبه المنطقى .

الخطوة الثانية: إذا كان هذا الخط صفرا فإن المعالج يذهب لتنفيذ الأمر التالى وأما إذا كان واحدا high فإن ذلك يعنى طلبا للمقاطعة. عندها إذا كان علم المقاطعة يساوى واحدا عن طريق الأمر EI فإن المعالج سيقبل المقاطعة ويكمل تنفيذ الأمر الحالى ويدفع بمحتويات عداد البرنامج إلى المكدسة stack حتى يتمكن من العودة إلى نفس المكان الذى خرج منه.

الخطوة الثالثة: يقوم المعالج بجعل علم المقاطعة IF صفر المنع أى مقاطعة من المصادر الأخرى (بالطبع ما عدا المقاطعية من الخط INTA عندما يكون فعالا الخط INTA فعالا بجعله يساوى صفر الله المحالة الخط INTA عندما يكون فعالا يعنى أن المعالج قد قبل المقاطعة ومفر المعالم وهو في إنتظار تحديد المكان الذى سيقفز إليه ليبدأ تتفيذ برنامج خدمة المقاطعة وذلك لأنه وكما هو مبين في شكل (13-9) فإن هذا الخط ملحق به ثمانية عناوين يمكن القفز إلى أى واحد منها عن طريق تنفيذ الأمر IE RST ميث صفر إلى سبعة ويتم القفز إلى أى واحد منها عن طريق تنفيذ الأمر IE RST ميث بعد قليل حيث تستخدم الإشارة IE المعالج عن طريق دائرة خارجية سنعرفها المعالج الأمر IE RST ورقم العنوان المطلوب القفز إليه .

الخطوة الرابعة: عندما يقرأ المعالج الأمر RST n من على مسار العناوين فإنسه يقفز إلى العنوان المحدد بهذا الأمر ليبدأ تنفيذ برنامج خدمة المقاطعة من هناك . الخطوة الخامسة: قبل الانتهاء من برنامج خدمة المقاطعة يجب أن نضع الأمر EI ثم الأمر RET في نهايته حتى ننشط المقاطعة فيصبح المعالج جاهزا لاستقبال المقاطعات الأخرى عند عودته إلى مكانه الذي خرج منه في البرنامج الأصلى عن طريق إسترداد محتويات عداد البرنامج التي دفعها إلى المكدسة .

# 4-4-13 كيف يتم تحديد العنوان الذي سيتم القفز إليه في حالة المقاطعة INTR ؟

كما ذكرنا في الخطوة الرابعة فإن المعالج بعد أن يجعل الخط  $\overline{\text{INTA}}$  فعالا يكون في إنتظار قراءة أمر معين من على مسار البيانات وهذا الأمر هو الأمر  $\overline{\text{RST n}}$  الذي يتكون من بايت واحدة تحتوى شفره لرقم العنوان الذي سيتم القفر إليه . شكل ( $\overline{\text{RST n}}$ ) يبين جدو لا لجميع حالات الأمر  $\overline{\text{RST n}}$  والعنوان المصاحب لكه حالة حيث نلاحظ من هذا الجدول أن البتات  $\overline{\text{DS n}}$  و  $\overline{\text{D4}}$  و  $\overline{\text{CD nnth}}$  الرقم  $\overline{\text{n}}$  في حالة . شكل ( $\overline{\text{CI}}$  –  $\overline{\text{IO}}$ ) يبين دائرة مقترحة لإدخال شفرة الأمر  $\overline{\text{RST n}}$  على مسار البيانات فور نزول الخط  $\overline{\text{INTA}}$  إلى الصفر . تتكون هذه الدائرة أساسا من أي شريحة بوابات ثلاثية المنطق ولتكن الشريحة  $\overline{\text{TA244}}$  مثلا والتي تحتوى على من المعالج ويوصل خرج الشريحة على مسار البيانات . توصل جميع خطه من المعالج ويوصل خرج الشريحة على مسار البيانات . توصل جميع خطه وط الدخل بالواحد high ما عدا الثلاثة خطوط  $\overline{\text{D5}}$ ,  $\overline{\text{D4}}$ ,  $\overline{\text{D4}}$  فقو تم فد المناسبة للرقم  $\overline{\text{n}}$  المطلوب مع الأمر  $\overline{\text{RST n}}$  كما في الجدول المبين في شكل ( $\overline{\text{CI}}$  ) . شكل ( $\overline{\text{CI}}$  ) يبين هذه الدائرة وقد تم ضبط هذه المفاتيح الثلاثة لتعطى الأمر  $\overline{\text{RST 5}}$  )

| RST n الأمر | <b>D</b> 7 | <b>D6</b> | <b>D</b> 5 | <b>D</b> 4 | D3 | D21 | D11 | 00 | شفرة الأمر | العنوان |
|-------------|------------|-----------|------------|------------|----|-----|-----|----|------------|---------|
| RST 0       | 1          | 1         | 0          | 0          | 0  | 1   | 1   | 1  | C7         | 0000    |
| RST 1       | 1          | 1         | 0          | 0          | 1  | 1   | 1   | 1  | CF         | 0008    |
| RST 2       | 1          | 1         | 0          | 1          | 0  | 1   | 1   | 1  | D7         | 0010    |
| RST 3       | 1          | 1         | 0          | 1          | 1  | 1   | 1   | 1  | DF         | 0018    |
| RST 4       | 1          | 1         | 1          | 0          | 0  | 1   | l   | 1  | E7         | 0020    |
| RST 5       | 1          | 1         | 1          | 0          | 1  | 1   | 1   | 1  | EF         | 0028    |
| RST 6       | 1          | 1         | 1          | 1          | 0  | 1   | 1   | 1  | F7         | 0030    |
| RST 7       | 1          | 1         | 1          | 1          | 1  | 1   | 1   | 1  | FF         | 0038    |

شكل (13-9) الأمر RST n شفرته وعناوين القفز

لاحظ أن الدائرة الموجودة في شكل (13-10) تكافىء تماما بوابـــة إدخــال تــم الاستغناء عن عمليات تشفير عنوان لها واستخدم الخط INTA كخط فعالية لــهذه البوابة بحيث أن هذه البوابة ستضع دخلها على مسار البيانات فقط عندما يكـــون الخط INTA فعالاً.

إن الأمر RST n يمكن تنفيذه من خلال البرنامج وليس بالضرورة أن ينفذ عـــن طريق إدخاله على مسار البيانات كما رأينا ، فإنه يمكن في أي مكان في البرنامج

أن تنفذ الأمر RST n حيث سيقفز المعالج إلى العنوان المتوافق مع الرقم وسينفذ برنامج المقاطعه الموجود هناك تماما كما لو كان المعالج تمت مقاطعت من الخارج من على الخط INTR وهذه تسمى مقاطعة عسن طريق البرمجة software interrupt . بذلك نكون قد إنتهينا من الطرق المختلفة لمقاطعة المعالج . 8085



# 280 مقاطعة المعالج 5-13

#### 1-5-13 الخط NMI

هناك خطان أساسيان لمقاطعة المعالج Z80 وهما الخط NMI على الطرف رقم 17 في الشريحة والخط NMI على الطرف رقم 16. بالنسبة للخط NMI والسذى يعنى مقاطعة غير محجوبة Nonmaskable Interrupt فإنه فعال عندما يكون صفرا wow و لا يهم أن يبقى صفرا لكى يجيب المعالج على المقاطعة ولكن يكفى

أن يهبط الجهد على هذا الطرف من الواحد إلى الصفر لكى يسجل المعالج طلب المقاطعة ، أى أن الحافة الهابطة هى الحافة المهمة لهذا الطرف . عندما ينتهى المعالج من تنفيذ أى أمر فإنه يختبر خط المقاطعة MMI فإذا كان فعالا يقوم فورا يعمل الآتى :

1. يقوم المعالج بدفع محتويات عداد البرنامج في المكدسة حتى يتمكن من العودة إلى نفس المكان الذي خرج منه في البرنامج الأساسي قبل طلب المقاطعة مثلب في ذلك مثل البرامج الفرعية subroutines.

2. القلاب IFF1 يعتبر علم المقاطعة في المعالج Z80 بحيث لا يسمح بالمقاطعة إلا إذا كان هذا القلاب يساوي واحد . في البرنامج الأساسي عادة يقوم المبرمج بوضع هذا القلاب إما واحد أو صفرا على حسب ظروف البرنامج إذا كان سيسمح بالمقاطعة من على الخط INT أم لا ، ولذلك فإن المعالج يقوم بتخزين قيمة هذا القلاب في قلاب آخر IFF2 حتى إنه عندما يرجع إلى البرنامج الأساسي بعد خدمة المقاطعة يسترجع القيمة الأصلية للقلاب IFF1 من القلاب IFF2 والتي كانت قائمة قبل المقاطعة . يقوم المعالج بهذه العملية نتيجة لأنه سيغير من قيمة القلاب IFF1 كما سنرى .

3. يوضع القلاب IFF1 يساوى صفرا وبذلك تمنع أو تحجب أى مقاطعة من على الطرف INT وذلك بالطبع نتيجة لأهمية المقاطعة IMM وأولويته على المقاطعة INT واذلك فإنه لا يسمح بالمقاطعة من على هذا الطرف إلا في حالات الطوارىء كما ذكرنا سابقا ولذلك فإنه بمجرد أن يبدأ المعالج في خدمة هذه المقاطعة فإنه تمنع أى مقاطعة أخرى من أى طرف آخر.

 يقفز المعالج إلى العنوان 40066H في الذاكرة والذي من المفروض أن يبدأ من عنده برنامج خدمة المقاطعة للطرف NMI .

5. لابد وأن ينتهى برنامج خدمة المقاطعة بالأمر RTI والذى يعنى عـودة مـن مقاطعة Return from Interrupt والذى على أثـره يقـوم المعـالج باسـترجاع محتويات عداد البرنامج من المكدسة فيرجع إلى البرنامج الأساسى ولنفس المكان الذى تمت عنده المقاطعة ، كما يقوم باسترجاع محتويـات القـلاب IFF1 مـن القلاب IFF2 بذلك يعود كل شىء إلى حالته قبل المقاطعة تقريبا .

6. إذا كان برنامج خدمة المقاطعة سيغير من قيمة أى من المسجلات المهمة في البرنامج الأساسى فإن مسئولية دفع قيم هذه المسجلات إلى المكدسة في بدايسة برنامج خدمة المقاطعة ثم استرجاعها مرة أخرى في نهايته تقع على المبرمج وذلك لأن المعالج لا يقوم بتخزين كافة المسجلات .

7 - إذا بقى الخط NMI فعالا حتى عند الانتهاء من الخدمة والعودة إلى البرنامج الأساسى فإن ذلك سيسبب مقاطعة أخرى وهذه بالطبع حالة غير مرغوب فيها ، لذلك فإن إزالة طلب المقاطعة من على الخط NMI بعد الانتهاء من برنامج

الخدمة تقع أيضا على عاتق المستخدم وعليه أن يأخذها في اعتباره. أيسر الطرق لذلك هي استخدام نبضة - واحد صفر واحد - كالمبينة في شكل (13-11) لطلب المقاطعة وذلك لأنه كما ذكرنا فإن الخط حساس للحافة الهابطة ولا فائدة من ابقاء الخط أو مسكه على حالة الصفر ، لذلك فإن استخدام متلل هذه النبضة ستغنى المستخدم عن إضافة دوائر أخرى تزيل طلب المقاطعة إذا كان سيبقى ممسوكا على الصفر .

الحافة الفعالة المقاطعة شكل (13-11) استخدام مثل هذه النبضة لا يحتاج لإزالة طلب المقاطعة بعد خدمتها

#### 2-5-13 الخط INT

خط المقاطعة INT يدخل على الطرف رقم 16 في المعالج 280 . المقاطعة على هذا الخط يمكن حجبها باستخدام الأمر Disable Interrupt في Disable والذي يجعل علم المقاطعة IFF1 يساوي صفرا ، بذلك لا يمكن قبول أي مقاطعة على هذا الخط . يمكن تنشيط المقاطعة مرة ثانية باستخدام الأمر EI والذي يعنى ها المحالط المقاطعة المقاطعة IFF1 يساوي واحدا وبذلك فإن أي مقاطعة على الخط Interrupt على الخط INT تقبل ويقوم المعالج بخدمتها . الخط INT يكون فعالا عندما يكون صفرا wol و لابد لكي تقبل المقاطعة من على هذا الخط أن يظل صفرا إلى أن تقبل المقاطعة من على هذا الخط أن يظل صفرا إلى من بالحافة كما رأينا في حالة المقاطعة المقاطعة 2 ويمكن تحديد أو إختيار أي من الطرق الثلاثة باستخدام واحد من الأوامر التالية ، IM2, IM1, IM0 وذلك من داخل البرنامج الأساسي . لاحظ أن المعالج Z80 عند بداية تشعيله أو إعادة وضعة أي RESET يكون في الطريقة 0 .

الطريقة 0 للتعامل مع الخط INT: هذه الطريقة تماثل تماما طريقة مقاطعة المعالج 8085 من على الخط INTR والتي سبق شرحها بالتفصيل حيث أنه عندما يستقبل المعالج 280 طلب مقاطعة على الخط INT (طرف 16) فإنه يقفز إلى واحد من ثمانية عناوين في الذاكرة يقوم المستخدم بتحديده للمعالج عند طلب

المقاطعة . هذه العناوين الثمانية سبق تحديدها في شكل (13-9) ويمكن مراجعتها للتذكرة (لذلك ننصح بقراءة الجزء 13-4-3 والجزء 13-4-4) . عندما يستقبل المعالج Z80 طلب مقاطعة على الخط  $\overline{INT}$  وعندما يكون في الطريقة 0 أي أنه سبق تنفيذ الأمر  $\underline{IMO}$  فإن المعالج يقوم بتنفيذ الخطوات التالية:

ا. يقوم المعالج بتصفير علم المقاطعة IFFI لحجب أى مقاطعات أخرى من أى أجهزة أخرى تطلب على نفس الخط INT .

2. يقوم المعالج بجعل الخطين  $\overline{\text{IORQ}}$  و  $\overline{\text{MI}}$  في حالة فعالية ، أى أن كل واحد من هذين الخطين يصبح صفرا low ، والحالة الوحيدة التي يصبح فيها هذان الخطان صفرا معا وفي نفس الوقت هي حالة المقاطعة على الخط  $\overline{\text{INT}}$  بالطريقة 0 والتي نحن بصددها الآن . لاحظ أن الخط  $\overline{\text{IORQ}}$  معناه طلب قراءة من جهاز إدخال ويقوم المعالج بتنشيط هذا الخط لأنه سيكون في هذه الحالة في إنتظار قراءة الأمر  $\overline{\text{RST n}}$  كما شرحنا في حالة المعالج  $\overline{\text{8085}}$  . وأما الخط  $\overline{\text{MI}}$  فإنه يكون فعالا فقط عند قراءة شفرة أى أمر ، وحيث أن المعالج في حالتنا هذه بالذات يقرأ شفرة الأمر  $\overline{\text{RST n}}$  من على بوابة إدخال فإنه سيكون هو أيضا فعالا في نفس اللحظة التي سيكون فيها الخط  $\overline{\text{IORQ}}$  فعالا .

3. على المستخدم أن يستغل ظاهرة أن الخطين  $\overline{\text{MI}}$  و  $\overline{\text{IORQ}}$  يكونان صفرا معا في هذه الحالة فقط لتشغيل بوابة إدخال يدخل عليها شفرة الأمر RST n معا في هذه المعالج أي واحد من عناوين القفز الثمانية سيقفز إليه . هذه البوابة موضحة في شكل (13–12) . لاحظ أن الفرق الوحيد بين المعالج 280 و المعللج 8085 هو فقط في طريقة تشغيل هذه البوابة حيث كما رأينا في حالة المعالج 8085 يستخدم الخط  $\overline{\text{INTA}}$  لتشغيل هذه البوابة كما في شكل (13–10) .

4. يقرأ المعالج بوابة الإدخال ويفك شفرة الأمر RST n ليعرف العنوان الذى سيتم القفز إليه .

5. يقوم المعالج بدفع محتويات عداد البرنامج في المكدسة .

6. يقفز المعالج إلى برنامج خدمة المقاطعة بناء على العنوان الــذى قــرأه فــى الخطوة 4.

7. بعد الانتهاء من تنفيذ برنامج خدمة المقاطعة يرجع المعالج إلى نفس المكان في البرنامج الأصلى عن طريق جلب محتويات عداد البرنامج مرة ثانيسة من المكدسة.

الطريقة 1 للتعامل مع الخط INT: هذه الطريقة بسيطة جدا حيث أنها تشبه تماما طريقة المقاطعة من على الخط NMI حيث أن هناك عنوانا واحدا فقط و هو العنوان 0038H يتم القفز إليه في حالة المقاطعة بهذه الطريقة . لاحظ أنه لابد من تنفيذ الأمر IM1 قبل طلب المقاطعة في البرنامج الأساسي ، كما أن علم المقاطعة لابد وأن يكون واحد ، أي أنه تم تنفيذ الأمر EI أيضا لتتشيط هذا العلم وحتى

يمكن قبول المقاطعة . عند المقاطعة بهذه الطريقة أيضا يقوم المعالج بدفع محتويات عداد البرنامج إلى المكدسة وعلى المبرمج دفع باقى المسجلات إن أراد في بداية برنامج خدمة المقاطعة حيث أن المعالج لا يقوم بذلك .

الطريقة 2 للتعامل مع الخط INT: يدخل المعالَّج في هذه الطريقة بناء على تنفيذه للأمر IM2 ، وعند إستقباله لطلب مقاطعة يقوم بالخطوات التالية:

1. يقوم المعالج بوضع صفر في علم المقاطعة İFFI لمنع أي مقاطعة أخرى مثل الطرق السابقة .



2. مثل الطريقة 0 يقوم المعالج بجعل الخطين  $\widetilde{M}$  و  $\widetilde{IORQ}$  فعالين بجعل كـــل منهما يساوى صفرا . على المبرمج مثل ما شرحنا فــى حالــة الطريقــة 0 أن يستغل ذلك لإدخال شفرة معينة إلى مسار البيانات مـــن علــى بوابــة إدخــال كالموضحة في شكل (12-12) .

3. يقوم المعالج بتكوين عنوان من 16 بتا وهذا العنوان يتكون من جزأين : الجزء الأول من العنوان وهو A0 إلى A7 هو الشفرة التي تمت قراءتها من على

بوابة الإدخال كما فى الخطوة 2 وأما الجزء الثانى من العنوان A8 إلى A15 فهو محتويات المسجل I الموجود فى المعالج لهذا الغرض والذى يتكون من 8 بتلت. عنوان برنامج خدمة المقاطعة فى هذه الحالة يكون موجودا فى البايت المحسددة بالعنوان السابق والبايت التى تليها .

4. بعد معرفة هذا العنوان يقفز إليه المعالج لينفذ برنامج خدمة المقاطعة الموجود هناك وذلك بالطبع بعد دفع محتويات عداد البرنامج إلى المكسة حتى يستطيع العودة إلى نفس المكان في البرنامج الأصلى بعد الانتهاء من برنامج خدمة المقاطعة .

5. يمكن أن نوضح ذلك بالمثال التالى: افترض أن محتويات المسجل I هي 10H ، وعند قراءة بوابة الإدخال المقصودة وجد بها الرقم 45H . لذلك سيكون المعالج العنوان التالى 1045H ويذهب إلى هذه البايت ليقرأ محتوياتها ولتكن مثلا 00H ثم يذهب إلى البايت التالية لها أى البايت 1046H فيقرأ محتوياتها ولتكن مثلا E1H . من محتويات هاتين البايتين يتكون لدى المعالج عنوان برنامج خدمة المقاطعة الذى يكون E00H فى هذا المثال .



كما رأينا فإنه لابد وأن يبقى الخط TNT ممسوكا على الصفر حتى تتهم خدمته بواسطة المعالج وإلا فإنه إن رجع إلى الواحد قبل أن يتعرف المعالج عليه فله فله تتم خدمته وذلك لأن الخط TNT من النوع الذى يكون فعالا على المستوى صفو وليس على أى حافة . لذلك فإنه يستحسن إدخال طلب المقاطعة عله الطرف آلات آلات عن طريق قلاب كما هو مبين في شكل (13-13) . وجود مثل هذا القلاب في مدخل المقاطعة بستازم أن يقوم ألمستخدم بإزالة هذا الصفر (طلب المقاطعة) عند نهاية برنامج الخدمة . شكل (13-13) يبين أيضا دائرة مقترحة لهذا الشأن حيث يتم إخراج أى معلومة على بوابة الإخراج أى معلومة على بوابة الإخراج المقاطعة . أى أنه بمجرد تنفيذ الأمر OUT FFH في نهاية برنامج خدمة المقاطعة سيزال طلب المقاطعة من على الطرف TNT أى

## 6-13 تـمـاريـن

- 1. ما هو المقصود بطرق الأبواب لخدمة الأجهزة ؟
- 2. ما هو الفرق بين طريقة طرق الأبواب لخدمة الأجهزة والمقاطعة ؟
  - 3. اشرح بعض التطبيقات التي تستخدم فيها المقاطعة ؟
  - 4. ماذا يفعل أي معالج عادة حال إستقباله لأمر مقاطعة ؟
- 5. كم عدد خطوط المقاطعة لدى المعالج 8085 التي يمكن مقاطعته من عليها ؟
- 6. كم عدد خطوط المقاطعة لدى المعالج 280 التي يمكن مقاطعته من عليها ؟
  - 7. الخط TRAP في المعالج 8085 ، ماذا يكافيء في المعالج Z80 ؟
- 8. الأمران DI و EI للمعالج 8085 يستخدمان عادة في برامج خدمة المقاطعة ،
   ما هو الغرض من استخدامهما ؟
- 9. اشرح دور الأمرين SIM و RIM في المقاطعة على الخطوط RST7.5, RST6.5, RST5.5,
- 10. ما هو الفرق بين المقاطعة على الخط INTR والخطوط الأخرى في المعالج 8085 والمعالج 280 والمعالج 983 ؟
- اشرح كيفية تحديد مكان برنامج خدمة المقاطعة للمعالج 8085 في حالة المقاطعة على الخط INTR ؟
  - 12. اشرح كيفية إدخال شفرة الأمر RST n إلى المعالج 8085 و Z80 ؟
- 13. من أوامر الشريحة Z80 الأوامر ، IM0 و IM1 و IM1 ماذا تعنيى هذه الأوامر وهل لها نظير في المعالج 8085 ؟ قارن بين الطرق الثلاثة لمقاطعة المعالج Z80 على الخط INT وما يناظرها في المعالج 8085 ؟
  - 14. قارن بين الشكلين (13-10) و (13-12) ؟

15. مطلوب إستخدام المعالج التحكم في نظام درجة حسرارة غرفة فسى أحسد المصانع وإظهار هذه الدرجة على شريحتين ذات 7 قطع, 7 segment إرسسم هذا النظام وإكتب برنامجه مرة مستخدما نظام طرق الأبواب ومسرة باستخدام المقاطعة ؟

# الفصل الرابح عشر

التركيب الهيكلى للمعالج Intel 8086/8088

## 1-14 مقدمة

تقدم في هذا الفصل شرحا تفصيليا للتركيب الهيكلي المعالج intel8086 وزميله المعالج intel8088 وذلك من الداخل حيث سندرس محتوياتهما من المسجلات والمعدادات ومن الخارج حيث سنلقى نظرة سريعة على وظيفة كل طرف من أطرافهما ، إن هذين المعالجين يعتبران أهم المعالجات ذات ال 16 بست وذلك الاستخدامهما في الحاسب IBM الذي كان من أول الحاسبات الشخصية التي ظهرت في السوق ثم سادت وفرضت نفسها على كل المستخدمين الحاسبات ، من ضمن هذا الجيل من المعالجات ظهر أيضا المعالج MC68000 والمعالج من ضمن هذا الجيل من المعالجات ظهر أيضا المعالجات الاستخدام هو المعالج كان كما ذكرنا كان أكثرها شيوعا وأوفرها حظا في الاستخدام هو المعالجات والمعالجات المعالجات المعالمة 
المعالجين 8086/8088 كل منهما كما رأينا يتعامل مع بيانات مقدار هـ 16 بت ، ولكن هناك نقطة خلاف أساسية ووحيدة بين هذين المعالجين وهي كيفية التعامل مع هذه البيانات . إن المعالج 8086 يتعامل مع البيانات في داخله وفي خارجه على أساس أنها 16 بت ، أي أنه له مسار بيانات خارجي مقداره 16 بت يستطيع من خلاله التعامل مع الأجهزة الخارجية مثل الشاشة والذاكرة ولوحة المفاتيح على أساس 16 بت ، فيرسل مثلا معلومة من 16 بت إلى الشاشة في مرة واحدة ويستقبل معلومة من 16 بت من أي بوابة إدخال . هذا المعالج ، 8086 يتعــامل داخليا أيضا بنفس الطريقة حيث تتثقل البيانات داخليا بيسن جميسع المسجلات بعضها البعض أو مع وحدة الحساب والمنطق على مسار بيانات مقداره 16 بـت أيضًا . أما المعالج 8088 فإنه تماما مثل نظيره 8086 في التعساملات الداخلية حيث ينقل البيانات داخله على مسار بيانات مقداره 16 بت ، بينما يختلف عن نظيره 8086 في التعاملات الخارجية حيث أن مسار البيانات الخارجي له يتكون من 8 بت فقط ، لذلك فإنه يرسل أو يستقبل بيانات 8 بـت فقط مع الأجهزة الخارجية ، وهذه كما ذكرنا هي نقطة الخلاف الوحيدة بين المعالجين كما سنرى فيما بعد . ونعتقد أن الرقم 6 في المعالج 8086 يذكرنا بأنه يتعامل دائما من خلال مسار بيانات 16 بت ، بينما الرقم 8 الأخير في المعالج 8088 فإنه يذكرنا بأن التعامل يكون من خلال مسار بيانات 8 بت فقط مع الأجهزة الخارجية · ويخطر ببالنا سؤال مهم هنا وهو: ما هو الداعي للمعالج 8088 إذا كان نظـــيره 8086 قد قام بالمهمة بكفاءة أحسن وبالتأكيد أسهل حيث يتعامل خارجيا وداخليا من خلال مسار بيانات 16 بت ؟ والإجابة على ذلك هي أن المعالجات 16 بت ظهرت في منتصف الثمانينات وحلت محل المعالجات 8 بت في جميع الحاسبات وجميع التطبيقات وبعد أن كانت المعالجات 8 بت قد انتشرت في السوق و استخدمت في كثير من أجهزة الحاسبات وفي الكثير من التطبيقات أيضا مما تسبب في أن كل هذه الأجهزة القديمة (8 بت) أصبحت عديمة الفائدة بعد أن فكر كل المستهلكين في الأخذ بالمعالجات الجديدة (16 بت) . لذلك كان التفكر في معالج وسيط يقلل من حجم الخسارة في عملية الانتقال إلى المعالج 8086 ، فكلن الحل هو معالج يتعامل داخليا على أساس 16 بت للاستفادة بمميزات ال16 بت ويتعامل خارجيا على أساس 8 بت لتسهيل عملية المواجهة مع الأجهزة الخارجية الموجودة أصلا في الحاسبات والتطبيقات التي كانت تتعامل مع المعالجات 8 بت وباقل تكافة ممكنة ، فكان ذلك المعالج الوسيط هو المعالج 8088 ، ولقد نزلت في هذا الوقت أيضا الكثير من البرامج التي تقوم بتحويل برمجيات المعالجات 8 بت المي صورة تناسب المعالجات 16 بت كمرحلة انتقال وحتى لا يعاد صياغة هدذه البرمجيات من جديد .

# 2-14 نظرة داخلية على محتويات المعالجين 8086/8088

كما علمنا من قبل وعند در استنا لشرائح المعالجات 8 بـــت أن أي معالج فــي النهاية يمكن النظر إليه على أنه مجموعة من المسجلات والعدادات بجانب وحدة الحساب والمنطق حيث أنها أهم المكونات الداخلية في المعالج ، أما فكرة عمـــل المعالج ، أي معالج ، فهي (كما سبق وشرحناها أيضا) إحضار شفرات الأوامر من الذاكرة وتتفيذها بنفس النتابع المسجلة به في البرنامج . أي أن الفكرة ثابتـــــة ولكن التطور يكون دائما في المكونات حيث تتغير المسجلات ووحدة الحساب والمنطق من 8 بت إلى 16 بت إلى 32 بت إلى 34 بت وتتغير تكنولوجيا التصنيع نفسها مع الزمن فتزداد السرعة بدرجة كبيرة ولكن فكرة العمل تظل كما هي ثابتة . شكل (1-14) يبين تطور المسجلات في المعالجات 8008 و 8085 و 8086 . نلاحظ من هذا الشكل أن عدد المسجلات كان 6 مسجلات كل منها 8 بت بخلاف المركم في المعالج 8008 وأما المعالج 8085 فيحتوى نفس العدد من المسجلات ولكن الجديد هو أن هذه المسجلات يمكن في بعض العمليات از دواجها واستخدامها كمسجلات 16 بت كما رأينا سابقا ولكن المركم كما هـو 8 بت ، وأما في المعالج 8086 فإنه يحتوى أيضا نفس العدد من المسجلات العامـــة والتي اختلفت أسماؤها قليلا لتناسب استخدامها كمسجلات 16 بـــت أو 8 بـت ، فمثلا المسجل B أصبح اسمه BX في حالة استخدامه كمسجل 16 بت أو BL في حالة استخدام النصف الأول منه كمسجل 8 بت و BH في حالة استخدام النصف الأعلى منه كمسجل 8 بت ، نفس الكلام مطبق على باقى المسجلات العامة وهسى المسجلات C, D . الجديد أيضا أن المركم مطبق عليه نفس الكلام السابق فيمكن استخدامه كمسجل 16 بت (AX) أو مسجلين كل منهم 8 بت (AL, AH) . نلاحظ أيضًا أن المكدسة stack كانت موجودة بداخل المعالج 8008 ثم انتقلب لتصبيح

جزءا من الذاكرة يشار إلى قمتها أو أول مكان فاضى فيها بمحتويات المسجل SP أو مؤشر المكدسة وذلك في المعالجات 8085 و 8086 . أما عداد البرنــــامج PC فكان 8 بت في المعالج 8008 وأصبح 16 بتا في المعالجات 8085 و 8086 وأصبح اسمه مؤشر الأوامر IP في المعالج 8086 وهذاك فرق كبير بين الاسمام "عداد البرنامج" و"مؤشر الأوامر" بالرغم من التماثل في الوظيفة ولكن في حالــــة المعالج 8085 فإنه يتعامل مع ذاكرة مقدارها 64 كيلو بايت وأما في حالة المعللج 8086 فإنه يتعامل مع ذاكرة مقدارها 1 ميجابايت من خلال فكرة زكيسة وهمي فكرة تجزىء الذاكرة التي سنشرحها بعد قليل إن شاء الله . نلاحظ أيض ا من شكل (1-14) أن المعالج 8086 يحتوى على مسجلات أخرى لم تكن موجودة في سابقیه و هی المسجلات BP, SI, DI, CS, DS, SS, ES و کلها مسجلات 16 بـــت ستتعرف على وظيفة كل منها بعد قليل . نلاحظ أيضا أن مسجل الأعلام أصبيح 16 بت أيضا بدلا من ثمانية مما ينبئ بأنه سيكون هناك الكثير من الأعلام وبالتالي مقدرة أكثر على البرمجة وعدد أكثر من الأوامــر . مـن الملاحظــات المهمة أيضا في شكل (1-14) هي احتواء المعالج 8008 على المكدسة كمجموعة من المسجلات موجودة بداخل المعالج نفسه في حين أصبحت هذه المكدسة جزء من الذاكرة في المعالجات التي تلت ذلك مما أمكن معه تكبير المكسة لأي كمية مطلوبة.

# 3-14 نظرة تفصيلية على مسجلات المعالج 8086/8088

لقد استخدم مصمموا المعالجين 8086/8088 فكرة زكية كان لها أكبر الأثر فى زيادة سرعة وكفاءة هذين المعالجين وهذه الفكرة هى انقسام هذه المعالجات إلى وحدتين أساسيتين لكل منهما وظيفة مختلفة تماما عن الوحدة الأخرى .

الوحدة الأولم ولا تتعداها لأى وظيفة أخرى ، والوحدة الثانية هي وحدة مواجهة المسارات (Ewecution Unit (EU) وظيفة أخرى ، والوحدة الثانية هي وحدة مواجهة المسارات (BIU) Bus Interface Unit (BIU) وهذه أيضا لها وظيفة محددة وهى جلب الأوامر من الذاكرة ووضعها في طابور أو قائمة انتظار وسودة في انتظار التنفيذ عن طريق وحدة التنفيذ . هذا التقسيم في الوظائف بين الوحدتين أتساح لوحدة التنفيذ أن تقوم فقط بتنفيذ الأوامر الموجودة في قائمة الانتظار وفي أثناء انشخال وحدة التنفيذ بتنفيذ الأوامر تقوم وحدة مواجهة المسارات بجلب أوامر أخرى من الذاكرة ووضعها في القائمة والعمل على أن تكون القائمة مملوءة دائما بسالأوامر التنفيذ .



بذلك تم توفير وقت كبير كانت وحدة التنفيذ تتوقف فيه لحين الذهاب إلى الذاكرة وإحضار الأوامر التى عليها الدور فى التنفيذ مما كان له أكبر الأثر فسى زيادة سرعة هذه المعالجات بدرجة كبيرة . يمكن تمثيل مهمة كل من هاتين الوحدتيان بمهمة المدير والسكرتارية حيث تكون السكرتارية هى المواجهة للعالم الخارجي حيث تستقبل هى جميع الطلبات والمشاكل من الجمهور واعدادها فى ملف كل على حسب ترتيب قدومه ثم تعرض هذا الملف على المدير الذى يقوم بحل هذه المشاكل فى حين تعمل السكرتارية على استقبال الطلبات الأخرى لحين أن ينتهى المدير من تنفيذ ما معه من طلبات . بالطبع فإن ذلك يكون له أكبر الأثسر فلى سرعة تنفيذ الطلبات عن ما لو كان المدير وحده يقوم باستقبال كمية من الطلبات ثم يجلس لتنفيذها وبعد أن ينتهى من تنفيذ هذه الكمية يقوم ليستقبل كمية أخسرى وهكذا .

بعض المسجلات داخل المعالج 8086 تتبع وحدة التنفيذ والبعض الآخر يتبع وحدة المواجهة على حسب وظيفة كل مسجل من هذه المسجلات حيث يجب أن نتوقسع أن جميع المسجلات العامة DX, CX, BX, AX ومسجل الأعلام والمسجلات SP, SS, DS, CS ومؤشر DI, SI, BP, ومدة التنفيذ وأما المسجلات ES, SS, DS, CS ومؤشر الأوامر IP فتتبع وحدة المواجهة تبعا لوظيفة كل منها كما سنرى .

على ضوء ما ذكرنا في المقدمة عن الفرق بين المعالجين 8086 و 8088 فإنسا يجب أن نتوقع أن وحدة النتفيذ EU في كل من المعالجين ستكون نفسها تماما وأما وحدة المواجهة BIU فستختلف في المعالج 8088 عنها في المعالج 8088 حيث أنها في الأول ستتعامل مع مسار بيانات 16 بت بينما ستتعامل مع مسار بيانات 8 بتات في المعالج الثاني وهذا هو وجه الاختلاف الأساسي بينهما .

## 1-3-14 المسجلات عامة الأغراض

يحتوى المعالج 8086 على أربع مسجلات عامة الأغراض كل منها 16 بتا وهي المسجلات يمكين التعامل المسجلات يمكين التعامل معها على أنها مسجلين كل منهم 8 بتات أو مسجل واحد 16 بيت . في حالية التعامل معها على أنها مسجلات 8 بتات في النصيف الأدني أو ذو القيمية المسغرى Low significant half يرمز له دائما بالرموز التالية, High significant half فيرمز ليه دائما بالرموز التالية High significant half فيرمز ليه دائما بالرموز التالية DH, CH, BH, AH الناسف الأعلى من 16 بيت مثل الرقم المسجل في المسجل BH مثلا فإن النصف الأعلى من المعلومة وهيو المعلومة وهو 16 فيوضع في النصف الأعلى من المسجل وهو BH وأما النصف الأدني من المعلومة وهو المعلومة وهو 16 فيوضع في النصف الأعلى من المسجل وهو 18 وأما النصف الأدني من المعلومة وهو المعلومة وهو 18 فيوضع في النصف الأدنى من المسجل وهو 18 فيما يلين

#### AX المسجل

المسجل AX هو المركم accumulator وكما سنرى عند دراستنا للغة الأسمبلى للمعالج 8086 فإن المركم لن تكون له نفس الأهمية التى رأيناها عنصد دراستنا للمعالجات 8 بت ، حيث هنا سنرى أنه يمكن إجراء أى عملية حسابية أو منطقية على أى مسجلين مع بعضهما البعض وليس من الضرورى أن يكسون المركم واحد منهما ، كما أن نتيجة هذه العملية تكون دائما في المسجل الأول في الأمر ، فمثلا الأوامر التالية كلها صحيحة :

#### ADD AX, BX

حيث سيجمع محتويات المسجل AX مع المسجل BX ويضع النتيجة في المسجل AX الذي هو المركم .

#### ADD CX, BX

حيث سيجمع محتويات المسجل CX مع المسجل BX ويضع النتيجة في المسجل CX ، وهكذا . هذا و لا زالت عمليات الإدخال والإخراج باستخدام الأمريان IN و OUT تتم عن طريق المركم كما هو الحال فلي المعالجات 8 بلت ولكن بإمكانيات أكثر وكفاءة أحسن كما سنرى عند الدراسة التفصيلية لهذه الأوامر .

#### المسجل BX

إن المسجل BX بجانب كونه أحد المسجلات العامة التي تستخدم في كل أغراض البرمجة مثل العمليات الحسابية والمنطقية وعمليات الإزاحة والدوران وغيرها فإن له وظيفة أخرى محددة وخاصة به عند تنفيذ بعض الأوامر مثل الأمر XLAT والذي ينشئ جدو لا في الذاكرة أول عنوان فيه هو الموجود في المسجل BX وتتكون عناصر هذا الجدول بتخزين محتويات النصف الأدنى من المركم AL في عناوين متتالية في الذاكرة تتكون بجمع محتويات المسجل AL مع محتويات المسجل Base كما سنرى عند شرح أوامر لغة الأسمبلي فيما بعد . لذلك فإن المسجل BX يحتوي عنوان البداية أو القاعدة Base للجدول السذى يتكون بالأمر XLAT . كما أن المسجل BX يستخدم في أغراض العنونة غير المباشرة حيث يمكن وضع العنوان المراد التعامل معه في ذاكرة البيانات فيه .

#### المسجل CX

المسجل CX أيضا بجانب كونه أحد المسجلات العامة مثل المسجلين BX, AX فإن له أيضا مهمة محددة خاصة به عند تنفيذ بعض الأوامر . فمثلا عند تنفيذ الأمر LOOP والذى ينفذ حلقة أو مجموعة من الأوامر عددة مرات فإن عدد المرات المراد تنفيذها لهذه الحلقة يوضع في المسجل CX . أي أنه عداد أو LOOP الحلقات عند تنفيذ الأمر LOOP .

#### المسجل DX

هذا المسجل أيضا بجانب كونه أحد المسجلات العامة فله أيضا وظيفة محددة عند تتفيذ بعض الأوامر ، فعند تتفيذ أمر ضرب رقمين كل منهما 16 بت فإن النصف الأعلى most significant part من النتيجة يوضع في هذا المسجل (لاحظ أن النتيجة ستكون 32 بت) . كذلك عند تتفيذ بعض أو امر الإدخال والإخراج فإن المسجل DX يوضع به عنوان البوابة المراد الإخراج عليها أو الإدخال منها . أي أن هذا المسجل DX أحد وظائفه الخاصة هي أنه يحتوى جزء من البيانات عند تتفيذ أو امر ضرب أو قسمة رقمين كل منهما 16 بتا . وعلى ذلك فإن الأربع مسجلات السابقة لها أسماء كما رأينا تطابق الرموز التي أطلقت عليها والوظيفة الخاصة المنوطة بكل واحد من هذه المسجلات والتي سنعيدها كما يلى:

| Accumulator | AX | المركم   |
|-------------|----|----------|
| Base        | BX | القاعدة  |
| Counter     | CX | العداد   |
| Data        | DX | البيانات |

هناك أيضا مجموعة من المسجلات التي يمكين أن تدخيل ضمين مجموعة المسجلات العامة حيث أنها تكون تحت تصرف المبرمج ولكنها لها وظيفة محددة أيضا في عمليات البرمجة فهي تستخدم إما للإشارة إلى أماكن محددة في الذاكرة وأيضا في عمليات الفهرسة Index عند التعامل مع الذاكرة بهذه الطريقة. هذه المسجلات هي كالتالي:

#### مؤشر المكدسة أو المسجل Stack Pointer, SP

المكدسة stack هي جزء مقتطع من الذاكرة يخزن فيه عادة البيانات المهمة قبل القفز من البرنامج الأساسي إلى برنامج فرعي أو برنامج مقاطعة والتي سستكون هناك حاجة إليها عند العودة مرة ثانية إلى البرنامج الأساسي بعد إنهاء البرنامج الفرعي (انظر فصل البرامج الفرعية) أو الانتهاء من خدمة المقاطعة (انظر فصل المقاطعة) . من أهم هذه البيانات مثلا محتويات مؤشر الأوامر IP حتى يتسنى لنا العودة لنفس المكان الذي خرجنا منه في البرنامج الأساسي وكذلك محتويات أي مسجل آخر قد نخاف من ضياعها أو تغيرها عند الخروج من البرنامج الأساسي مثل مسجل الأعلام والمركم . هذه البيانات تخزن في المكدسة بالترتيب ويتم استدعاؤها بنفس الترتيب على أساس أن آخر ما تم تخزينه يكون أول ما يتم استدعاؤه (Last In First Out (LIFO) فإن مسجل مؤشر المكدسة (Stack Pointer (SP) يحتوي عنوان آخر مكان تسع النخزين فيه في هذه المكدسة .

#### مسجل مؤشر القاعدة Base Pointer, BP

أحد المسجلات العامة التي تستخدم لعنونة أو للإشارة على بداية مجموعة بيانات أو طابور array بيانات موجود في المكدسة stack .

## مسجلي الفهرسة SI, DI

يستخدمان في عملية العنونة غير المباشرة (المفهرسة) في الذاكرة indirect معملية العنونة المختلفة . addressing

## 2-3-14 المسجلات الخاصة

المسجلات الخاصة الموجودة في المعالج 8086/8088 هي مسجل مؤشر الأوامسر (IP) Instruction Pointer (IP) وأربع مسجلات خاصة بتجزىء الذاكرة سنطلق عليها اسم مسجلات التجزىء Segmentation registers . عدد هذه المسجلات أربعة وهي : ES, SS, DS, CS . لكي نأخذ فكرة عن وظيفة هذه المسلحلات ، لابد أن نعرف أو لا ما هو المقصود بتجزىء الذاكرة؟ ولماذا يتم تجزىء الذاكرة؟

# 4-14 تجزىء الذاكرة Memory segmentation

مسار العناوين في المعالج 8086/8088 يحتوى 20 بت أو بمعنى آخر يتكون من 20 خطا وهذا يعنى أن هذا المعالج يستطيع التعامل مع ذاكرة مقدارها 20ء أو 1048576 بايت أو اختصارا تكتب 1 ميجابايت (1 م.ب) . هذا يعنى أننا نستطيع مثلاً أن نكتب أي برنامج في خلال هذا المدى من الذاكرة والذي يبلغ 1 م.ب كما ذكرنا وعلى المعالج أن يحضر أوامر هذا البرنامج من الذاكرة وينفذها بالتنابع بلا أدنى مشاكل . إن هناك مشكلة صعبة تعوق المعالج من إمكانية إحضار الأوامر من الذاكرة بهذه السهولة وذلك لأن عداد البرنامج أو مؤشر الأوامر الاأوامر من الذاكرة بهذه السهولة وذلك لأن عداد البرنامج أو مؤشر الأوامر IP كما أسميناه هنا يحتوى على 16 بت فقط ، وكما نعلم أن مهمة المسجل IP هي أنه يحتوى عنوان الأمر الذي عليه الدور في التنفيذ ، وهذا يعنى بالتالي أن أي أمر يقع في الذاكرة خارج المدى العنواني صفر الي 64 ك.ب لن يستطيع المعالج التعامل معه من خلال هذا المسحب هو المدى العنواني الذي يستطيع المعالج التعامل معه من خلال هذا المسحب هو ميفر إلى 261 أي 65536 بايت في الذاكرة التي يبلغ مداها 1 م.ب وليس فقط نريد كتابة البرامج في أي مكان في الذاكرة التي يبلغ مداها 1 م.ب وليس فقط في أول 64 ك.ب؟ شكل (1-2) ببين المدى العنواني للمعالج 8088 على ضدوء

عدد خطوط مسار العناوين ، والمدى العنواني الذي يمكن التعامل معه من خلال المسجل IP .

إن حل هذه المشكلة جاء من خلال استخدام فكرة زكية تمكنك كمبرمج من التعامل مع كل المدى العنواني للذاكرة الذي يبلغ 1 م.ب بالرغم مسن استعمال مسجلات 16 بت فقط وكان ذلك من خلال استخدام أربع مسجلات سميت بمسجلات تجزيء الذاكرة memory segmentation registers وكل منها 16 بت ويرمز لها بالرموز التالية ES, SS, DS, CS وهذه الرموز لها دلالات تتطابق مع وظيفة كل مسجل سنعرفها بعد قليل.

كل واحد من هذه المسجلات ، مسجلات التجزيء ، يحتوى عنوان من 16 بــت ولكن الظريف هذا أن هذه 16 بت تقابل أعلى 16 بت من مسار العنبلوين أى A4 ولكن الظريف هذا أن هذه 16 بت قابل أعلى A15 . أى أن محتويات أى واحد من هذه المسجلات أن تمثل عنوانا حقيقيا فى الذاكرة إلا بعد إزاحتها ناحية اليسار بمقدار 4بت أى بمقدار خانة ستعشرية أو بضربها فى الرقم 16 ضربا عشريا للحصول على عنوان من 20 بت .



فمثلا بافتراض أن المسجل CS محتوياته كالتالى: CS=0800H في العنوان العنوان الفعلى المقابل لهذه المحتويات هو 08000H بإضافة OH ناحية اليمين أى بإزاحة الرقم 4 بتات ناحية اليسار أو بضربه في الرقم 16 ضربا عشريا . وكذلك إذا كانت محتويات المسجل DS كالتالى: DS=12F5H فإن العنوان الفعلى المقابل

لهذه المحتويات هو 12F50H في الذاكرة. هنا يظهر سؤال مهم وهو كيف يتـــم إحضار الأوامر من الذاكرة باستخدام مؤشر الأوامر IP الذي يتكون هو الآخــر من 16 بت فقط ؟ وهل هذا المسجل له علاقة بمسجلات التجزيء ؟

بفرض أن محتويات مسجل التجزىء CS هـــى CS=12F0H ، وأن محتويسات مؤشر الأوامر IP هى IP=001BH فما هو العنوان الحقيقى فى الذاكــرة للأمــر الذى عليه الدور فى التنفيذ ؟ يتحدد هذا العنوان بعد أن يقــوم المعــالج بــإجراء الخطوتين التاليتين :

1-محتویات مسجل التجزیء CS تتم إزاحتها ناحیة الیسار بمقدار 4 بـت فتصبح المحتویات الجدیدة هی :

CS=12F00H

قبت محتويات مؤشر الأوامر مع محتويات المسلح CS بعد الإزاحة -2 فيتكون لدينا العنوان الحقيقي كالتالي :

أى أن الأمر الذي عليه الدور في النتفيذ سيكون موجودا في الذاكرة في العنــوان 12F1BH (20بت) كما رأينا في المثال السابق . من ذلك نفهم حقيقة مهمة جدا وهي أن مؤشر الأوامر يشير أو يحدد عنوان في الذاكرة منسوبا أو محسوبا بمحتويات المسجل CS . ولنضرب لذلك المثال التوضيحي التالي : افترض أن لدينا سيارة هنا في القاهرة وأقصى ما تستطيع أن تفعله هذه السيارة هـو السـير في دائرة نصف قطرها 5 كيلومتر لتوزيع الحليب مثلا ، هذه هي مقدرتها! ... فهل تستطيع هذه السيارة أن توزع الحليب في لندن ؟ نعم تستطيع إذا نقلناها السي لندن بالطائرة! إن هذه السيارة تقابل مؤشر الأوامر الذي يحتوى فقط 16 بت و لا يستطيع التعامل إلا مع 64 كيلو بايت فقط ولكن هذه 64 كيلو بــايت تتحــدد بدايتها بمحتويات المسجل CS بعد إزاحتها ، وبذلك فإن مؤشر الأوامر يستطيع جلب أى أمر من أى مكان في الذاكرة التي تبلغ 1 ميجابايت بعد جمع محتوياته مع محتويات المسجل CS التي تمت إزاحتها لليسار ، تماما مثل الســـيارة التـــي تستطيع أن توزع الحليب في أي مكان في العالم بعد نقلها بالطائرة للمكان المطلوب . الذلك فإنه في بداية أي برنامج البد من تحميل المسجل CS بالعنوان الذي نرغب في كتابة البرنامج ابتداء منه وهذا العنوان بالطبع يكون في أي مكان خلال الذاكرة التي تبلغ 1 ميجابايت ، هنا يظهر سؤال وهو: لماذا ارتبط مؤسر الأوامر IP بالمسجل CS بالذات ولم يرتبط بأى واحد آخر من مسجلات التجزىء مثل المسجل DS أو SS مثلا ؟ إن ذلك يرجع إلى الوظيفة المحددة لكل واحد من هذه المسجلات والتي نبينها فيما يلي :

1-4-14 مسجل تجزيء البرامج Code Segment register, CS

يحتوى هذا المسجل عنوان بداية جزء من الذاكرة يبلغ 64 كيلو بايت يخصص لكتابة شفرات البرامج فيه فقط، ولذلك فإن مؤشر الأوامر يرتبط دائما بهذا المسجل لأن مؤشر الأوامر يشير على عنوان الأمر الذى عليه الدور فى التنفيذ و لابد أن الأمر يقع فى هذا الجزء من الذاكرة، ويتحدد العنوان الحقيقى للأمر كما ذكرنا بإضافة محتويات مؤشر الأوامر مع محتويات المسجل CS بعد إزاحتها 4 بت ناحية اليسار. يمكن أن تتغير محتويات المسجل CS فصى أثناء تنفيذ البرنامج مع أوامر القفز أو النداء على البرامج الفرعية وذلك فصى حالات خاصة سيأتى شرحها بعد ذلك.

2-4-14 Data Segment register, DS مسجل تجزيء البيانات

يحتوى هذا المسجل على عنوان بداية جزء من الذاكرة يبلغ 64 كيلو بايت أيضا وهذا الجزء يحتوى جميع البيانات التى يتعامل معها أو يحتاجها البرنامج ، تتم عنونة هذه البيانات بإضافة محتويات المسجل DS بعد إزاحتها لليسار 4 بت مصع محتويات أى واحد من المسجلات DX أو BX أو SI أو DI كما سنرى عند در اسنتا لطرق العنونة .

3-4-14 مسجل تجزيء المكدسة Stack Segment register, SS

يحتوى هذا المسجل عنوان بداية جزء من الذاكرة يبلغ 64 كيلو بايت يستعملها المعالج كمكدسة . تستخدم المكدسة لتخزين البيانات والعناوين الضرورية عند القفز إلى البرامج الفرعية أو القفز إلى برنامج لخدمة مقاطعة حيث من شأن هذه البيانات والعناوين التي تخزن في المكدسة أن تساعد المعالج على الرجوع إلى نفس المكان الذي تم القفز منه في البرنامج الأساسي واسترجاع القيسم الحقيقية لجميع المسجلات التي كانت موجودة قبل القفز بحيث يرجع المعالج إلى تغير سير البرنامج الأساسي من حيث انتهى قبل القفز تماما دون خوف من تغير سير البرنامج بسبب فقد محتويات أحد المسجلات . يتم سحب البيانات من المكدسة على أساس أن آخر ما تم تسجيله يكون هو أول ما يتم سحبه أي أن آخر بايت تم تخزينها تكون أول بايت يتم سحبها Last In First Out, LIFO ، تتم عملية السحب والإضافة في المكدسة وبالتتابع الذي أشرنا إليه بمساعدة مسجل مؤشر المكدسة المكدسة عنوان آخر مكان في المكدسة تم التخزين فيه وبالطبع فإن مقدار المكدسة على عنوان آخر مكان في المكدسة تم التخزين فيه وبالطبع فإن مقدار المكدسة يتحدد به 64 كيلو بايت كما ذكرنا . يتم تحديد العنوان الفعلى أو الحقيقي داخيا يتحدد به 64 كيلو بايت كما ذكرنا . يتم تحديد العنوان الفعلى أو الحقيقي داخيان عن طريق إزاحة محتويات مسيحل تجيزيء

المكدسة SS ناحية اليسار بمقدار 4 بتات ثم إصافة محتويات مؤشر المكدسسة اليها.

Extra Segment register, ES مسجل التجزيء الإضافي Extra Segment register, ES كيلو بايت يحتوى هذا المسجل على عنوان بداية جزء من الذاكرة يبلغ 64 كيلو بايت تستخدم لتخزين البيانات أيضا وبالذات سلاسل الحروف strings . يتحدد العنوان الحقيقي أو الفعلى لأى معلومة داخل هذا الجرزء بإزاحة محتويات مسجل التجزىء ES ناحية اليسار بمقدار 4 بتات ثم يضاف إليه محتويات أى من المسجلين DI أو SI على حسب الأمر الذي يتم تنفيذه .

شكل (14-3) يبين محتويات مقترحة لكل واحد من مسجلات التجزىء والمسلحة الفعلية التي يشغلها الجزء المقابل لكل مسجل على خريطة الذاكرة . نلاحظ مسن شكل (3-1) أن هذه الأجزاء يمكن أن تتداخل مع بعضها البعض ، بل ويمكن أن تشغل كلها نفس الجزء من خريطة الذاكرة .



Status Register. SR مسجل الأعلام أو مسجل الحالة Status Register. SR يحتوى هذا المسجل على 16 بت مستخدم منها 9 بتات فقط كأعلام وباقى بتات المسجل غير مستخدمه . إن كل بت أو علم من هذه الأعلام يعكس حالة معينة

من حالات نتيجة آخر عملية أو منطقية قام المعالج بتنفيذها . وفيما يلى نقدم هذه الأعلام والحالة التي يعكسها أو يبينها ومتى يكون كل علم صفرا ومتى يكون واحدا على ضوء هذه النتيجة (سبق شرح معظم هذه الأعلام ولكن لا مانع مسن مراجعة سريعة لوظائفها) .

## Carry flag, CF علم الحمل -1

إذا حصل حمل أو استلاف من أو إلى آخر بت نتيجة إجراء أى عملية حسابية أو منطقية فإن علم الحمل يصبح واحدا ، ويكون صفرا فيما عدا ذلك . يتاثر هذا العلم أيضا ببعض أوامر الإزاحة والدوران .

## 2- علم الباريتي Parity flag, PF

إذا احتوت نتيجة آخر عملية أو منطقية نفذها المعالج على عدد زوجى من الوحايد فإن علم الباريتي يصبح واحدا ، أما إذا احتوت النتيجة على عدد فردي من الوحايد فإن هذا العلم يصبح صفرا .

# Half carry flag, HF علم الدمل النصفي

يكون هذا العلم واحدا إذا حصل هناك حمل أو استلاف من أو إلى البت الثالثة (منتصف البايت) عند إجراء أى عملية حسابية أو منطقية . لاحظ أننا نعد البتات في أي بايت ابتداء من الصفر ، أي البت رقم صفر ورقم واحد وهكذا .

#### 4-علم الصفر Zero flag, ZF

يكون هذا العلم واحدا إذا كانت نتيجة آخر عملية حسابية أو منطقية نفذها المعللج تساوى صفرا، ويكون هذا العلم صفرا إذا كانت النثيجة تختلف عن الصفر.

#### Sign flag, SF علم الإشارة -5

يوضح هذا العلم إشارة نتيجة آخر عملية حسابية أو منطقية نفذها المعالج ، فـــإذا كانت هذه النتيجة سالبة يكون هذا العلم واحدا وإذا كانت هذه النتيجة موجبة فــإن هذا العلم يكون صفرا . لاحظ أن المعالج يعتبر النتيجة سالبة إذا كانت آخر بــت فيها تساوى واحدا ويعتبر النتيجة موجبة إذا كانت آخر بت تساوى صفرا . مــن ذلك نقول أن علم الإشارة يساوى دائما آخر بت في النتيجة .

# 6-علم الفخ أو المصيدة Trap flag, TF

هذا العلم لا يعكس نتيجة عملية نفذها المعالج ولكنه حينما يكون واحد فإن المعالج ينفذ البرنامج خطوة بخطوة وحينما يكون صفر فإنه ينفذها بالطريقة المعتادة.

# 7-علم تنشيط المقاطعة Interrupt enable flag, IF

لكى يمكن مقاطعة المعالج 8088/8086 فإنه يتم إعطاؤه إشارة على طرف طلب المقاطعة INTR (الطرف 18 في شريحة المعالج) ولكن هذه المقاطعة ان يقبلها المعالج إلا إذا كان علم المقاطعة IF فعال أي يساوى واحدا هو الآخر .

## 8-علم الاتجاه Direction flag, DF

هناك بعض الأوامر الخاصة بالتعامل مع سلاسل الحروف character strings فلك بعض الأوامر الخاصة بالتعامل مع سلاسل الحروف SI, DI حيث يزاد واحد أو ينقص واحد من محتويات هذيان المسجلين ليشير إلى مكان معين في هذه السلسلة . يبين علم الاتجاه DF إذا كان سيكون هناك نقص بمقدار واحد على محتويات هذيان المسجلين . إذا كان DF=1 فإن ذلك يعنى أنه سيكون هناك زيادة بمقدار واحد على محتويات هذيا المسجلين ، وبالطبع إذا كان DF=0 فإن ذلك يعنى أنه سيكون هناك إنقاص بمقدار واحد على هذه المحتويات .

## Overflow flag, OF علم الفيضان -9

يبين هذا العلم إذا كان هناك فيضان حسابي في نتيجة أي عملية حسابية مثل الجمع والطرح أم لا . فمثلا في حالة جمع الرقم 7FH الذي يساوي (+127) مع الرقم (1H) فإن النتيجة تكون 80H والتي تعتبر سالبة بعد أخذ المتمم الثنائي لها وتساوي (-128) ، ولأن الرقم (-128) يعتبر غير صحيح لأن أي رقسم سالب يجب ألا يتعدى (-127) فإن علم الفيضان يكون واحد . وعلى ذلك فإن هذا العلم يكون صفرا طالما لم يكن هناك فيضان في النتيجة .

| 127   | 7FH  |
|-------|------|
| 001 + | +01H |
| 128-  | 80H  |

# 14-5 طرق العنونة Addressing modes

فى أثناء تنفيذ المعالج لأى برنامج فإنه ينقل بيانات من مسجل إلى مسجل آخو أو من مسجل إلى مكان ما فى الذاكرة أو من مكان ما فى الذاكرة إلى مكان ما فى الذاكرة أو من مكان ما فى الذاكرة إلى مسجل داخل المعالج نفسه . هناك طرق مختلفة يمكن استخدامها لكى يتم ذلك وهذه الطرق المختلفة يجب أن يلم بها أى مبرمج حتى يكون برنامجه ذو كفاءة عالية . سنقدم فى هذا الجزء شرحا مفصلا لهذه الطرق المختلفة من خلال استخدام الأمر MOV كمثال تطبيقى ، يقوم الأمر MOV بنقل معلومة من مكان (المصدر) وهذا المصدر يكون إما مسجل داخل المعالج نفسه أو بايت من بايتات الذاكرة إلى مكان آخر (الهدف) وهذا الهدف أيضا يكون إما مسجل أو مكان فى الذاكرة . الصورة العامة لهذا الأمر هى :

MOV destination, source حيث تنتقل المعلومة من المصدر إلى الهدف وكمثال على ذلك الأمر التالى :

MOV AX,BX

حيث تتثقل محتويات المسجل BX إلى المسجل AX وهو المركم . نلاحظ أنها دائما يكتب مصدر المعلومة بعد الفاصلة من ناحية اليمين وأمها الهدف الهذى ستتقل إليه المعلومة فيكتب بجانب الأمر MOV وقبل الفاصلة .

Register addressing mode عنونة المسجل 1-5-14

تستخدم هذه الطريقة لنقل معلومة (بايت أو كلمة ، والكلمة 2 بايت) من مسجل إلى مسجل آخر ، أى أن مصدر المعلومة يكون مسجلا وكذلك السهدف . وهذه الطريقة تعتبر أسرع الطرق لنقل معلومة من مكان إلى مكان حيث كل من مصدر وهدف المعلومة يكون مسجلا داخل المعالج نفسه ولا يتعامل المعالج مع الذاكرة على الإطلاق . كمثال على ذلك الأمران :

MOV CX.AX

. (الذي ينقل محتويات المسجل AX (16بت) إلى المسجل CX (16بت أيضًا) MOV AH,AL

الذى ينقل محتويات النصف الأول AL من المسجل AX إلى النصف الثاني AH في المسجل نفسه.

من المهم جدا هنا أن نلاحظ أحجام المسجلات التي نتعامل معها ، فلا يصح مثلا أن ننقل محتويات مسجل 8 بت إلى مسجل 16بت أو العكس حيث سيعطى الأسمبلر رسالة خطأ على ذلك لأن ذلك غير مسموح . الجدير بالذكر هنا أنه في مثل هذه الأوامر فإن مسجل المصدر لا تتغير محتوياته ولكن يؤخذ منها نسخة أو صورة وتوضع في المسجل الهدف . فالأمر MOV CX,AX مثلا يأخذ نسخة من محتويات المسجل AX ويضعها في المسجل الهدف . كدن تغير فسى محتويات المسجل AX والذي يتغير فقط هو المسجل الهدف .

## 2-5-14 العنونة الفورية mode العنونة الفورية

تستخدم هذه الطريقة لنقل معلومة (بايت أو كلمة) موجودة فى الأمر نفسه إلى مسجل من المسجلات . أى أن مصدر المعلومة هنا ليس مسجلا داخل المعالج ولا بايت فى الذاكرة ولكن المعلومة تعتبر ثابت أو قيمة موجودة فى الأمر نفسه ويعد شفرة الأمر مباشرة ، كمثال على ذلك الأمر :

MOV AX, 34F6H

الذى يضع نسخة من الثابت أو الرقم أو المعلومة 34F6H المكونة مسن 16بت والموجودة في البرنامج بعد شفرة الأمر MOV في المسجل AX . لاحظ أن H في آخر أي رقم تعنى أن هذا الرقم مكتوبا فسي النظام الستعشري . بعض الأسمبلر تضع العلامة # أمام الثابت أو المعلومة الفورية ولكنها قليلة ونحن فسي

هذا الكتاب لن نتبع ذلك وسنضع أى ثابت بدون هذه العلامة ، فقط سنضع حوف H للدلالة على أن الرقم ستعشرى أو إذا كان الرقم فى النظام العشرى فلن نضع أى علامة .

# 3-5-14 العنونة المباشرة Direct addressing mode

هذا يتعامل المعالج مع الذاكرة حيث سيرسل لها أو يستقبل منها معلومة ، وعلى ذلك لابد من تحديد عنوان هذه المعلومة . في العنونة المباشرة يحتوى الأمر نفسه على العنوان المباشر للمعلومة أو الثابت المراد جلبه أو إرساله من أو إلى الذاكرة . تذكر جيدا أن هذا العنوان يحدد نسبة إلى محتويات مسجل التجرون DS أو مثلا الأمر MOV AL,[1234H] معناه نقل نسخة من محتويات العنوان العنوان المسجل AL . لاحظ أنه بفرض أن محتويات المسجل المسجل DS=2000H معناه نقل نسخة سيكون العنوات العنوان الفعلي المعلومة السابقة سيكون المحتويات المسجل المسجل DS=2000H النسار عبد أن العنوان الغنوان الفعلي المعلومة السابقة سيكون العنوان العنوان الفعلي المعلومة السابقة سيكون كثيرا الفعلية . إذا كان العنوان الذي سيتم التعامل معه في جزء البيانات سيتكرر كثيرا في البرنامج فإنه يمكن في أول البرنامج إعطاء رمزا لهذا العنوان ثم بعد ذلك يستخدم هذا الرمز للدلالة على هذا العنوان في أي مكان في البرنامج . فمثلا يمكن أن نرمز للعنوان الكاللة على هذا العنوان كما في الأمر NUMBER المستخدم الرمز الأمر NUMBER EQU 1234H في أول البرنامج ، ثم بعد ذلك نستخدم الرمز MOV AL,NUMBER

# 4-5-14 العنونة غير المباشرة 4-5-14

هذه الطريقة من العنونة تسمح بالتعامل مع بيانات موجودة في الذاكرة حيث العنوان الذي سيتم التعامل معه في هذه الحالة يكون موجودا في أحد مسحلات المعالج التالية: BX, BP, SI, DI . كمثال على ذلك افترض أن المسجل BX . MOV AX,[BX] يحتوى الرقم 1000H وطلبنا من المعالج تنفيذ الأمر التللي: [RX] . MOV AX,[BX] . في هذه الحالة سيقوم المعالج بإحضار نسخة من محتويات العنوان المسجل BX (والذي يليه) ويضعها في المسجل AX . أي أن محتويات المسجل BX الموضوع بين قوسين مربعين كما رأينا تمثل عنوان المعلومة وليس المعلومة انفسها ، ففي عدم وجود القوسين سينسخ المعالج محتويات المسجل BX ويضعها في المسجل AX كما رأينا في أول طرق العنونة (عنونة المسجل) . يجب أن نؤكد هنا أن العنوان الفعلي للمعلومة يحسب منسوبا لمحتويات مسجل التجزيء DS بعد إزاحته ناحية اليسار 4 بتات كما ذكرنا سالفا ، أي أنه إذا كانت محتويات المسجل AX . لاحظ أبضا أن

المسجلات BX, SI, DI تعنون عناوين منسوبة إلى مسجل التجـزىء DS بينما المسجل BP فيعنون عناوين منسوبة لمسجل التجزىء SS . كأمثلة علـي هـذا النوع من العنونة انظر إلى الأوامر التالية :

MOV CX,[BX] MOV [BP],BL

MOV [DI], AH

MOV [DI],[BX] (خطأ)

حيث الأمر الأول سينقل محتويات عنوان (والذي يليه) في جزء البيانيات أو ذاكرة البيانات data segment المشار إليه بالمسجل BX إلى المسجل CX ، بينملا الأمر الثاني سينقل محتويات النصف الأول من المسجل BX إلى عنوان مشار إليه بالمسجل BP ويقع في جزء المكدسة . الأمر الثالث سينقل النصف العلوي من المسجل AX إلى عنوان مشار إليه بالمسجل DI ويقع في جزء البيانات ، أملا الأمر الرابع فغير مسموح به لأنه ينقل من ذاكرة إلى ذاكرة وهذا النوع من العنونة غير مسموح به إلا في حالات خاصة جدا مع بعصض أوامر سلاسل الحروف .

#### 5-5-14 عنونة القاعدة زائد الفهرسة Base plus index addressing

تعتبر هذه الطريقة من العنونة بمثابة عنونة غير مباشرة ولكن طريقة تكوين أو الحصول على العنوان تختلف عن الطريقة السابقة . هنا المسجلين BP و BR يستخدمان كقاعدة base أو كبداية لمجموعة أو صف أو مرصوصة مسن العناوين حيث BX تستخدم في حالة وجود مرصوصة البيانات في جزء البيانات في جزء البيانات في حذا البيانات في جزء المكدسة . في هذا النوع من العنونة يتكون العنوان بجمع محتويات واحدة من مسجلات القاعدة BX أو BP مع محتويات واحد من مسجلات الفهرسة SI أو DI . يوضح ذلك المثال

MOV DL,[BX+DI]

حيث سينسخ المعالج محتويات العنوان المكون من جمع محتويات المسجلين BX و DI ويضعها في النصف الأول من المسجل DX .

### 6-5-14 العنونة النسبية Relative addressing mode

هذا النوع من العنونة يختلف اختلافا بسيطا عن عنونة القاعدة زائد الفهرسة الذى تم شرحه سابقا حيث هنا يتم تحديد عنوان الذاكرة المراد التعامل معه عن طريق

جمع محتويات أحد المسجلات BX, BP, SI, DI مع إزاحة تعطى في الأمر نفسه كما في المثال التالي:

MOV AX,[BX+1000]

حيث هنا سيتم عنونة العنوان المحدد بجمع محتويات المسجل BX مع الرقم 1000H وهذا العنوان سيكون في جزء البيانات من الذاكرة المحدد بمحتويات المسجل DS. جدول DS ببين طرق العنونة السابقة مع مثال لكل طريقة ، حيث يمكنك مراجعته على ضوء ما سبق وبتأنى حتى يمكنك فهم هذه الطرق .

## 6-14 تمارين

- ا. ما هى المسجلات ذات 8 بت التى يمكن التعامل معها من خالل الأوامر المعالج 8086/8088 ؟
- 2. قارن بين المعالجات 4 و 8 و 16 و 32 من حيث سرعة التنفيذ إذا تساوت كل العوامل الأخرى ؟
- 3. ما هى وحدة التنفيذ ووحدة مواجهة المسارات فى المعالجين 8086/8088 ؟
   وما أثر هما على أداء المعالج ؟ وما هو الفرق بين كل وحددة في كل من المعالجين ؟
- 4. ما هو طابور الإحضار Prefetch Queue ؟ وما هو تأثيره على أداء المعالج؟ وكم عدد البايتات فيها في كل من المعالج 8086 و 8088 ؟
- ما هى المسجلات ذات 16بت ، والمسجلات ذات 8 بت التى يمكن التعـــامل
   معها من خلال الأوامر للمعالج 8086/8088 ؟
- 6. لماذا يطلق على المسجل CX مسجل العد Count register ؟ والمسجل DX مسجل البيانات Data register ؟
  - 7. ما هو الخطأ في أو امر الانتقال التالية:

MOV AL,BX MOV CS,SS MOV ES,F214H MOV [BX],[DI]

| ا الأمــــــــــــــــــــــــــــــــــــ | العنوان الفعلى للمعلومة في      |
|--------------------------------------------|---------------------------------|
| الامـــــــــــــــــــــــــــــــــــ    |                                 |
|                                            | الذاكرة                         |
| MOV AL,BL                                  | عنونة مسجل                      |
| MOV AL, temp                               | (10xDS)+temp                    |
| MOV AL,55H                                 | عنونة فوريةImmediate            |
| MOV AL,[BP]                                | (10xSS) + BP                    |
| MOV AL,[BX]                                | (10xDS) + BX                    |
| MOV AL,[DI]                                | (10xDS) + DI                    |
| MOV AL,[SI]                                | ′ (10xDS) + SI                  |
| MOV AL,[BP+5]                              | (10xSS) + BP + 5                |
| MOV AI,[BX+4H]                             | (10xDS) + BX + 4H               |
| MOV AL,[DI-66H]                            | (10xDS) + D1 - 66H              |
| MOV AL,[S1-400H]                           | (10xDS) + SI - 400H             |
| MOV AL, temp[BX]                           | (10xDS) + temp + BX             |
| MOV AL, temp[BP]                           | (10xSS) + temp + BP             |
| MOV AL, temp[SI]                           | (10xDS) + temp + SI             |
| MOV AL, temp[DI]                           | (10xDS) + temp + DI             |
| MOV AL, temp[BX+10H]                       | (10xDS) + temp + BX + 10H       |
| MOV AL, temp[BP-23H]                       | (10xSS) + temp + BP - 23H       |
| MOV AL, temp[SI+50H]                       | (10xDS) + temp + SI + 50H       |
| MOV AL, temp[DI+80H]                       | (10xDS) + temp + DI + 80H       |
| MOV AL,[BX+DI]                             | (10xDS) + DI + BX               |
| MOV AL,[BP+DI]                             | (10xSS) + DI + BP               |
| MOV AL,[BX+SI]                             | (10xDS) + SI + BX               |
| MOV AL,[BP+SI]                             | (10xSS) + SI + BP               |
| MOV AL,[BX+DI+8]                           | (10xDS) + DI + BX + 8           |
| MOV AL,[BP+DI-10H]                         | (10xSS) + DI + BP - 10H         |
| MOV AL,[BX+SI-7]                           | (10xDS) + SI + BX - 7           |
| MOV AL,[BP+SI+10H]                         | (10xSS) + SI + BP + 10H         |
| MOV AL, temp[BX+SI]                        | (10xDS) + temp + BX + SI        |
| MOV AL, temp[BP+SI]                        | (10xSS) + temp + BP + SI        |
| MOV AL, temp[BX+DI]                        | (10xDS) + temp + BX + DI        |
| MOV AL, temp[BP+DI]                        | (10xSS) + temp + BP + DI        |
| MOV AL, temp[BX+SI+9]                      | (10xDS) + temp + BX + SI + 9    |
| MOV AL, temp[BP+SI-10H]                    | (10xSS) + temp + BP + SI - 10H  |
| MOV AL,temp[BX+DI+200H]                    | (10xDS) + temp + BX + DI + 200H |
| MOV AL, temp[BP+DI+1FH]                    | (10xSS) + temp + BP + DI + 1FH  |

جدول 14-1

- 8. أكتب أوامر الانتقال التي تقوم بالأتي:
- تحميل المسجل BX بالمعلومة •
- تحميل العنوان 32000H بالمعلومة 0BH
- تصفير بايتات الذاكرة (أى جعل محتوياتها تساوى صفسرا) ابتداء مسن العنوان 32000H إلى 32050H بالتتابع
- نقل محتويات الذاكـرة 32000H حتـى 32050H إلـى 42000H حتـى 42050H
  - تحميل المسجلات CS, SS, DS, ES بالعنوان •
- 9. ما معنى وضع القوسين [] حول أى معامل من معاملات أى أمر ؟ 10. ما هو عنوان الذاكرة الذى سيتم التعامل معه فى كل من الأوامر التالية إذا كانت DS=3200H, BX=0200H, DI=0300H, BP=1000H, SS=2000H و list=0250H :
  - MOV AL,[3200H]
  - MOV AL,[BX]
  - MOV [DI],AL
  - MOV AL,[BX+100]
  - MOV AL,[BP+100H]
  - MOV AL,[BP+DI]
  - MOV AL, list[DI]
  - MOV AL, list[100H]
  - MOV AL,[BX+DI]

# الفصل الخامس عشر

برمجة المعالج Intel 8086/8088 والمحح Debugger

#### 1-15 مقدمة

سنرى في هذا الفصل الخطوات الأولى في اتجاه كتابة برنامج بسيط بلغة الأسمبلى الخاصة بالمعالج 8086/8088 ، ومن ثم تنفيذه ، كل ذلك مسن خال برامج بسيطة نقدمها فقط لنفهم منها مكونات برامج لغة الأسمبلى للمعالج 8086 . بعد ذلك يعرض هذا الفصل لمجموعات أو امر هذه اللغة عرضا سريعا الغسرض منه هو التعريف بأهم مفردات هذه اللغة . بالطبع سيتبقى هناك الكثير من الأوامر الأقل شيوعا ولكنها قد تفيد في الكثير من التطبيقات ولكننا لن نتعسرض لها هنا ونحيل القارئ إلى أحد الكتب المتخصصة في لغة التجميع المذكورة في قائمة المراجع في نهاية هذا الكتاب . إن الأمور عادة لا تأتي بكل ما يتمناه المبرمج ، حيث كثيرا ما نجد أن البرنامج يحوي العديد من الأخطاء التي تعوق المبرمج ، حيث كثيرا ما نجد أن البرنامج يحوي العديد من الأخطاء التي تعوق المبرمج ، مناء بالصورة المطلوبة . سنرى في هذا الفصل أيضا باذن الله كيفية استخدام برنامج بالصورة المطلوبة . سنرى في هذا الفصل أيضا باخن الله كيفية التخلص منها .

# 2-15 خطوات كتابة وتنفيذ برامج لغة التجميع

1. نبدأ بكتابة برنامج لغة الأسمبلى مستخدمين الأوامر المختلفة لهذه اللغة كما سنرى تباعا بعد ذلك . يجب أن يتضمن البرنامج بعض الأوامر الموجهة للأسمبلر لإخباره عن المتطلبات التي يحتاجها الأسمبلر عند تحويل البرنامج إلى لغة الماكينة . وأول هذه الأوامر هو أمر إخبار الأسمبلر عن مكان وضع البرنامج في الذاكرة مثلا ، وأيضا عن مكان وضع البيانات الناتجة عن البرنامج.

بعد الانتهاء من كتابة البرنامج يجب أن يخزن في ملف file بأي أسم مع مراعلة أن يكون امتداد هذا الملف ASM. ، فمثلا يمكن تسمية الملف بأي واحد من الأسماء التالية :

Example.ASM

Test. ASM

2. بعد ذلك يتم استدعاء الأسمبار وإدخال الملف الذي تمت كتابته في الخطوة 1 عليه ، حيث سيعطينا الأسمبار نتيجة ذلك ملف جديد بنفس الاسم السابق ولكن عليه ، حيث سيعطينا الأسمبار نتيجة ذلك ملف الهدف object file وسيكون كالتالي : بامتداد مختلف ؛ هذا الملف سنسميه ملف الهدف object file وسيكون كالتالي : example.obj

Test.obj

هذه الصورة من البرنامج تكون مكتوبة في صورة لغة الآلة ، ولكنها ما زالت غير مناسبة للتنفيذ بواسطة المعالج .

3. يتم بعد ذلك إدخال الملف السابق "ملف الهدف" على البرنامج الرابط linker الذي يقوم بتجميع الأجزاء المختلفة للبرنامج ، ووضعه في صورة مناسبة قابلة للتنفيذ executable بواسطة المعالج . هذه الصورة الجديدة للملف ستكون بنفسس الاسم ولكن بامتداد جديد و هو EXE. وذلك كما يلى :

Example .EXE

Test .EXE

بعد الانتهاء من الخطوات الثلاث السابقة يمكن تنفيذ البرنامج ، وكذلك يمكن رؤية خرجه ، فإذا كان الخرج على ما يرام . . نكون قد انتهيئا من البرنامج ، أما إذا جاءت النتائج على خلاف ما نتوقع ، فإن ذلك يدل على وجود أخطاء في البرنامج . . فكيف يمكننا إذن الكشف عن هذه الأخطاء والتعامل معها ؟ إن هذا يتم عن طريق استخدام برنامج الديبجر ، وسنرى في هذا الفصل كيفية الدخول في هذا البرنامج واستخدامه . شكل (1-1) يبين رسما توضيحيا لكتابة برنامج بلغة الأسمبلى ، وخطوات تنفيذه ، وذلك بفرض أن البرنامج تمت كتابته في ملف المعهد المعهد المعهد المعهد عنه المعهد ا

# 15-3 مكونات برنامج الأسمبلي

لكي تتعرف على مكونات برنامج لغة الأسمبلى ، سنسوق المثـــال الأول الــذي يكتب الرسالة الآتية " أهلا يا عرب ، استيقظوا " على الشاشة ، وذلــك دون أن ننشغل بتفاصيل البرنامج الآن ، حيث سيرد ذكرها فيما بعد بإذن الله .

#### مثال 1-15

DOSSEG
.MODEL SMALL
.STACK 100H
.DATA
message DB 'Hello Arab , woke up ',B,10,'\$'
.CODE
mov ax, @data
mov ds,ax; set ds to the beginning of the data segment



mov ah,9; load register ah evith 9

mov dx, offset message int 21h mov ah, 4ch int 21h END

#### من هذا المثال نرى الآتى:

1. وجود مجموعة من الأوامر في أول البرنامج وهي عبارة عن أوامر توجيهية للأسمبلر عن حقائق معينة للأسمبلر عن حقائق معينة للأسمبلر عن حقائق معينة يريد المبرمج أن يأخذها في الاعتبار ، مثل تحديد جزء ذاكرة البيانات stack وجزء ذاكرة المكدسة code segment ، وجزء ذاكرة المرنامج segment وكذلك نهاية البرنامج .

2. القسم الثاني من الأوامر هو أوامر لغة الأسمبلي مثل الأوامر سه و mov و sub و sub و غيرها ، وكلها عبارة عن أوامر سيقوم الأسمبلر بتحويلها إلي شفرات لغة الآلة و تخزينها في الذاكرة ، لاحظ أن الأوامر التوجيهية التي سبق الإشارة إليها لا يتم تحويلها إلي شفرات لأنها ليس لها شفرات أصلا ، وذلك لأنها ليست أوامر قابلة للتنفيذ بواسطة المعالج ، ولكنها مجرد توجيهات للأسمبلر لا يراها المعالج . فيما يلي سنأخذ فكرة موجزة عن أوامر التوجيه الموجودة في البرنامج السابق ، وهي كما يلي :

#### 1- أمر التوجيه DOSSEG

هذا الأمر هو أول ما يكتب في أي برنامج أسمبلي ، وهذا الأمر يجعل كل أجزاء البرنامج (البيانات و الكود) تتبع نظام الميكروسوفت في التجزيء ، وهذا النظلم لا يعنينا هنا في شئ ، ولن ننظر في أية تفاصيل أخرى له طالما أن هذا الأملر يقوم بهذه المهمة . المهم هنا هو أن نبدأ البرنامج بهذا الأمر كما ذكرنا .

#### .MODEL أمر التوجيه −2

يحدد هذا الأمر للأسمبلر موديل الذاكرة الذي سيتم التعامل معه ، حيث تبعا لهذا الموديل سيتحدد ما إذا كانت البيانات التي سيتعامل معها المعالج قريبة ؛ بحيه يتم عنونتها ب16 بت فقط داخل الجزء الخاص بها ، أم بعيدة فيتم التعامل معها على أساس 32 بت ، 16 منها تحدد العنوان داخل الجزء و 16 أخرى تحدد مكلن أو بداية هذا الجزء . وهناك أكثر من موديل للذاكرة يتعامل معها الأسمبلر كمها يلى :

#### 1- الموديل tiny :

في هذا الموديل يكون البرنامج والبيانات موجودة في نفس الجزء حيث الجزء يبلغ 64 ك ب .

#### 2- الموديل small :

يوجد كود البرنامج في جزء أو مقطع (64 ك ب) وبيانات البرنامج في جزء آخر منفصل عن الأول ولكن كلا من البرنسامج والبيانات لا يتعدى الجزء الموجود فيه .

#### 3- الموديل compact :

يوجد كود البرنامج في جزء معين ، أما بيانات البرنامج فيمكن أن تشخل أكثر من جزء واحد ، ولذلك فإن التعامل مع البيانات في هذه الحالة يكون على أساس أنها بعيدة ويكتب في 32 بت (segment : offset) بالرغم من أن البيانات هنا تشغل أكثر من جزء إلا أنه غير مسموح في هذا الموديل أن يكون لمصفوفة واحدة array أن تخرج خارج حدود هذا الجزء ، أي أن أي مصفوفة لا تتعدى 64 ك ب .

#### 4- الموديل large :

هنا يمكن لكود البرنامج وبياناته أن يشغل كل منهما أكثر مسن جسزء واحد ، وسيكون التعامل مع العناوين هنا على الأساس البعيد سسواء في حالمة كود البرنامج أو بياناته . هنا أيضا يجب أن لا يتعدى حجم أي مصفوفة 64 ك.ب .

#### 5- الموديل huge :

و هو يشبه تماما الموديل large في الوقت الحالي .

معظم البرامج التي نتعامل معها سواء في هذا المقرر أو في الكثير من التطبيقات الأخرى ، يكون الموديل small مناسبا جدا لها حيث أن البرنامج يكون مخصصا له 64 ك.ب ، وكذلك 64 ك.ب البيانات ، وهذا يعتبر كافي جدا لهذه التطبيقات . ويجب أن نستخدم هذا الموديل كلما أمكن إلا إذا كانت هناك ضرورة لغير ذلك لأن العنونة البعيدة الموجودة في الموديلات 3 ، 4 ، 5 تأخذ وقتا أطول في التنفيذ . وأخيرا يجب أن يوضع الأمر MODEL. قبل أوامر تحديد الأجزاء المختلفة stack. و data. و code.

#### 3- أمر التوجيه stack.

هذا الأمر يحدد كمية الذاكرة التي سيستخدمها البرنامج كمكدسة . والمكدسة يخزن فيها البرنامج عناوين الرجوع عند النداء على البرامج الفرعية ، أو تنفيذ برامج خدمة المقاطعة . إن 200 كلمة تعتبر مناسبة جدا كمكدسة في الكثير من الأغراض ، حيث يتم تحديد هذه الكمية كما في الأمر التالي :

.stack 200h

| .code | جيه | التو | أمر | -4 |
|-------|-----|------|-----|----|
|       |     |      |     |    |

هذا الأمر يحدد بداية الجزء الذي سنكتب فيه شفرات أو كود البرنامج . لاحظ أن هذا الأمر ليس له معاملات تكتب بعده كما كان في الأمر 200h . ولكن هذا الجزء يبدأ بالأمر code . وينتهى بالأمر END ، وكمثال على ذلك ما يلى :

.code
add ax,bx
sub ax,bx
mov cx,100

### 5- أمر التوجيه DATA.

هذا الأمر يحدد بداية جزء البيانات المستخدمة في البرنامج كما يلي:

.DATA

boundary DW 100 counter DW 2

message DW '\*\* ERROR MESSAGE \*\*', '\$'

.....

#### <u>6- أمر التوجيه END</u>

بهذا الأمر تتحدد نهاية البرنامج ، وبدون هذا الأمر يعطي الأسمبلر رسالة خطأ ، لأنه من الضروري أن ينتهي البرنامج بهذا الأمر .

ملحوظة: إن نسيان بعض أوامر التوجيه السابقة يسبب خطأ ، وبعضها يسبب تحذير ، لذلك نؤكد على ضرورة الالتزام بها .

شكل (15-2) يبين الصورة العامة لبرنامج أسمبلي وقد احتوى كل أوامر التوجيله السابقة .

DOSSEG
MODEL SMALL
STACK 100H
DATA
DB
DW
-----Code
Your program

END

شكل (2-15) الصورة العامة لبرنامج الأسمبلي .

## 15-4 أوامر لغة الأسمبلى

لغة الأسمبلى للشريحة 8088/8086 تحتوى العديد من الأوامر بحيث أنه سيكون من الصعب ومن الممل جدا أن ندرس هذه الأوامر عن طريق سردها الواحد بعد الآخر إلى أن نصل إلى نهايتها بحيث عندما نصل إلى النهاية نكون قد نسبنا مسادرسناه في البداية . لذلك فقد اخترنا أن نقسم هذه الأوامر إلى مجموعات كما فعلنا عند دراسة لغة الأسمبلي المعالجات السابقة بحيث ندرس كل مجموعة على حدة مع إعطاء بعض الأمثلة السريعة والتمارين على كل مجموعة ، معتمدين على أن الدارس لديه الخبرة الآن بمعظم أساسيات البرمجة بهذه اللغة .

## 5−15 مجموعة أوامر الانتقال Transfer instructions

هذه المجموعة من الأوامر خاصة بنقل البيانات من مكان لآخر دون إجراء أى تعديل أو تغيير عليها . الصورة العامة لهذه الأوامر هي :

mov destination, source source هى اختصار لكلمة move بمعنى أنقل أو حرك ، وأمل source ليث الكلمة و مصدر المعلومة ، و destination هو الهدف أو الملجأ السذى تذهب إليه المعلومة . أى أن المعلومة ستتقل من المصدر إلى الهدف . كل مسن المصدر

والهدف من الممكن أن يكون مسجلا من مسجلات المعالج أو عنوان من عناوين الذاكرة . كما يمكن أن يكون المصدر معلومة فورية immediate أو ثابت .

من أمثلة نقل البيانات بين المسجلات المختلفة ما يلي :

تقل محتويات المسجل bl (هبت) إلى المسجل al,bl; المسجل ax,cx; (ت ) ax المسجل المسجل المسجل عمر محتويات المسجل عمر (16يت) إلى المسجل عمر المسجل 
نقل محتويات المسجل sp (16بت) إلى المسجل bp,sp ; (ت ) bp إلى المسجل

mov ds, ax mov di,si mov bx,es

هذا الأمر خطأ لأنه لا يمكن نقل محتويات مسجل مقطع إلى ; mov cs,ds

إلى مسجل مقطع آخر

mov bl,ax ; تبدأ الأمر خطأ لأن المسجلين أحدهما 16 بت والآخر 8 بت ;

جميع الأوامر السابقة كانت تتعامل مع مسجلات فقط سواء كمصدر للمعلومة أو register هدف ستذهب إليه المعلومة . هذا هو ما يسمى أحيانا بعنونة المسجلات addressing حيث لا يكون هناك تعامل مع الذاكرة في طرفي الأمر ، فقط مسجلات . يمكن تحميل أي مسجل بمعلومة فورية immediate data بسبت أو 16 بت كما في الأوامر التالية :

mov al,03h

حيث هنا تم تحميل المسجل ax (16بت) بالمعلومة ff35h (16بت). عادة يوضع صفر قبل أى رقم ستعشرى يبدأ بحرف كما في المثال السابق.

من المفيد جدا في الكثير من البرامج أن نرمز لقيمة فورية بأي رمز ثم نستخدم هذا الرمز في البرنامج بدلا من القيمة الثابتة ، كما في الأوامر التالية :

kkk equ 33h

mov al,kkk

equ هو أمر توجيه جديد موجه للأسمبلر بإعطاء القيمة 33h للرمز kkk حيت يقوم الأسمبلر باستبدال الرمز kkk بقيمته عند كل موضع يظهر فيه هذا الرمسز في البرنامج .

#### مثال 15-2

أكتب برنامج يحمل المسجلات ah, al, bh, bl, ch, cl, dh بالقيم ,02, 03, 06 و04, 05, 06 على الترتيب ثم يقوم بعمل إزاحة دورانيسة على محتويسات هذه المسجلات . هذا المثال تم تناوله مع كل المعالجات 8 بت ولذلك سنقدم البرنسامج مباشرة كالتالى :

```
dosseg
.model small
.stack 100h
.data
.code
mov ah,00
mov al,01h
mov bh,02h
mov bl,03h
mov ch,04h
mov cl,05h
mov dh,06h
mov dl.dh
mov dh,cl
mov cl,ch
mov ch,bl
mov bl,bh
mov bh.al
mov al, ah
mov ah,dl
end
```

بعد كتابة هذا البرنامج سجله في ملف اسمه example1.asm وبعد ذلك استدعى الأسمبلر وأدخل عليه البرنامج باستخدام الأمر:

#### Tasm example1

للحصول على برنامج الهدف example1.obj - بعدد ذلك استدعى برنامج التوصيل tlinker التوصيل tlinker للحصول على الصورة القابلة للتنفيذ للبرنامج كما يلي :

بالحصول على الصورة القابلة للتنفيذ من البرنامج يمكنك تنفيذه باستخدام الأمر: example1

حيث سينفذ البرنامج ويرجع الحاسب إلى dos دون أن ترى نتيجـــة محسوســة للبرنامج لأن مثل هذا البرنامج لا يطبع شيئا على الشاشة ولا يرسل نتــائج إلــى الطابعة ، لذلك فلن تحس به لأنه فقط يغير مــن محتويــات المســجلات داخــل

المعالج . في مثل هذه الظروف يلعب الديبجر دورا مهما في أنه يمكننا به أن نرى نتيجة تنفيذ البرنامج في المسجلات ، حيث يمكسن باستخدام الديبجر أن نفحص كل مسجلات المعالج لنرى محتوياتها بعد تنفيذ البرنامج لنعرف هل تسم تنفيذ البرنامج بالطريقة المطلوبة أم لا . بل إنه من مزايا استخدام الديبجر أنه يمكننا تنفيذ البرنامج خطوة بخطوة لنرى نتيجة البرنامج بعد تنفيذ كل أمر ونفحص عند أي لحظة لنعرف هل البرنامج يسير على ما يرام أم لا . وهذه في الحقيقة تعتبر فائدة عظيمة في استخراج الأخطاء من البرامج ، لذلك سسنعرض في الجزء القادم لكيفية الدخول في البرنامج من الديبجر واستخدامه لتتبع تنفيذ البرنامج .

### 6-15 الديبجر Debugger

لكي تدخل في الديبجر لابد وأن يكون لديك الصورة القابلة للتنفيذ من البرنامج الذي تريد استخراج أخطاؤه أو التعامل معه ، لذلك يمكننا الدخول في الديبجر بالأمر التالي :

C:\TASM>debug example2.exe

بذلك تدخل في الديبجر وتظهر لك علامة وجودك فيه حيث يصبح دليل الكتابـــة Cursor هو الشكل '-' ويمكنك استخدام أو امره كالتالي :

## R إظهار محتويات المسجلات بالأمر R

بكتابة الحرف R (أو r لأن لغة الأسمبلي ليست حساسة لشكل الحرف) ثم enter تظهر أمامك جميع المسجلات بمحتوياتها كما يلي :

-- r

AX=0000 BX=0000 CX=001E DX=0000 SP=0100 BP=0000 SI=0000 DI=000 DS=272C ES=272C SS=273E CS=273C IP=0000 NV UP EI PL NZ NA PO NC

حيث نرى أن محتويات المسجل AX=0000 والمسجل CS=273C وهكذا . يمكنك إظهار محتويات مسجل معين بكتابة اسم المسجل بعد الحري R حيث تظهر لك محتويات هذا المسجل فقط وفي السطر التالي تظهر العلامة ': 'والتي تتيح لك تغيير محتويات هذا المسجل بكتابة المحتويات الجديدة بعد هذه العلامة وإذا لم تريد تغيير هذه المحتويات اضرب enter .

يظهر في آخر قائمة المسجلات بيان بحالة جميع الأعلام flags الموجودة في المعالج وحالة كل علم إذا كان واحد أم صفر . جدول (1-1) يبين قائمة بهذه

الأعلام وماذا يكتب فيها إذا كانت صفرا وماذا يكتب فيــها إذا كانت واحــد . سندرس معنى هذه الأعلام بالتفصيل عند دراستنا للقفز المشروط .

| اسم العلم | العلم مرفوع | العلم غير مرفوع |
|-----------|-------------|-----------------|
|           | set to one  | set to zero     |
| Over flow | OV          | NV              |
| Direction | DN          | UP              |
| Interrupt | EI          | DI              |
| Sign      | NG          | PL              |
| Zero      | ZR          | NZ              |
| Auxiliary | AC          | NA              |
| Parity    | PE          | PO              |
| Carry     | CY          | NC              |

جدول (15-1) بيان بحالة الأعلام التي يظهر ها الديبجر

## 2-6-15 عرض أو امر الأسمبلي ابتداء من عنوان معين Un

تحتوى الذاكرة الشفرات الثنائية لأوامر البرنامج ، وعرض هذه الشفرات الثنائية بنفس حالتها لا يفيد شئ حيث يكون من الصعب فهمها . لذلك فقد أتاح الديبجر بنفس حالتها لا يفيد شئ حيث يكون من الصعب فهمها . لذلك فقد أتاح الديبجر إمكانية عرض هذه الأوامر بشفرات الأسمبلي عن طريق كتابة الأمر Un والذي يعنى عرض n من الأوامر ابتداء من العنوان الموجود في المسجل CS كما يلي: يعنى عرض n من الأوامر ابتداء من العنوان الموجود في المسجل CS كما يلي:

AX=0000 BX=0000 CX=001E DX=0000 SP=0100 BP=0000 SI=0000 DI=0000 DS=1898 ES=1898 SS=18AA CS=18A8 IP=0000 NV UP EI PL NZ NA PO NC

| DO 1070 DO 1070 D | O TOINT | JU 10110 1 |
|-------------------|---------|------------|
| 18A8:0000 B400    | MOV A   | H,00       |
| -u0               |         |            |
| 18A8:0000 B400    | MOV     | AH,00      |
| 18A8:0002 B001    | MOV     | AL,01      |
| 18A8:0004 B702    | MOV     | BH,02      |
| 18A8:0006 B303    | MOV     | BL,03      |
| 18A8:0008 B504    | MOV     | CH,04      |
| 18A8:000A B105    | MOV     | CL,05      |
| 18A8:000C B606    | MOV     | DH,06      |
| 18A8:000E 8AD6    | MOV     | DL, DH     |
| 18A8:0010 8AF1    | MOY     | DH, CL     |
| 18A8:0012 8ACD    | MOV     | CL, CH     |
| 18A8:0014 8AEB    | MOV     | CH, BL     |
| 18A8:0016 8ADF    | MOV     | BL, BH     |
| 18A8:0018 8AF8    | MOV     | BH, AL     |
| 18A8:001A 8AC4    | MOV     | AL, AH     |
| 18A8:001C 8AE2    | MOV     | AH, DL     |

نلاحظ فيما سبق أن محتويات المسجل CS=18A8 ، لذلك تم عسرض الأوامسر ابتداء من العنوان موسبة لمحتويات هذا المسجل . بعد العنوان مباشرة ستجد شفرة الأمر الستعشرية ، فمثلا الأمر MOV AH,00 كانت شفرته B400 والأمسر MOV AH,DL شفرته هي BAE2 .

# 3-6-15 عرض محتويات جزء من الذاكرة بالشفرات الستعشرية بالأمر Dn

يمكن عرض محتويات جزء معين من الذاكرة بالأمر Dn حيث n هــى عنـوان البداية التى سيبدأ من عندها عرض المحتويات ، وعنـوان البدايـة يكـون هـو العنوان الموجود فى المسجل DS ، كما يلى :

C:\TASM>debug example2.exe

--r

AX=0000 BX=0000 CX=001E DX=0000 SP=0100 BP=0000 SI=0000 DI=0000 DS=1898 ES=1898 SS=18AA CS=18A8 IP=0000 NVUP EI PL NZ NA PO NC 18A8:0000 B400 MOV AH,00

-D0

1898:0000 CD 20 00 A0 00 9A F0 FE-1D F0 4F 03 FD 11 8A 03.....

1898:0010 FD 11 17 03 FD 11 EC 11-01 01 01 00 02 FF FF FF ......

1898:0020 FF 83 18 4C 01

1898:0030 98 18-FF FF FF FF 00 00 00 00

لاحظ أن محتويات المسجل DS=1898 وتم عرض محتويات أماكن الذاكرة منسوبة لهذا العنوان وكل سطر يبين محتويات 16عنوان (10 ستعشرى).

### 4-6-15 تنفيذ البرنامج حتى عنوان معين Ga

هذا الأمر يبدأ في تتفيذ البرنامج ابتدأ من العنوان المحدد بمسجل التجزيء CS ومحتويات مؤشر الأوامر IP ، أي عنوان بداية التنفيذ سيكون CS:IP . سيقف النتفيذ عند العنوان a الموجود بعد الحرف G بحيث لن يتم تنفيذ الأمر الموجود عند هذا العنوان . لذلك لتنفيذ البرنامج السابق من بدايته لابد من تصفير المسجل IP أولا باستخدام الأمر RIP – ثم تحميل المسجل IP بأصفار . بذلك سيبدأ التنفيذ من العنوان 1898:0000 . بعد ذلك نعطيه أمر التنفيذ من العنوان G001E - حيث

سيتوقف التنفيذ عند هذا الأمر الذي لا يدخل ضمن أوامر البرنامج ولذلك فإنه لن ينفذ .

# 5-6-15 متابعة تنفيذ البرنامج عن طريق تنفيذ عدد n من الخطوات Tn

يمكن متابعة Trace, T تنفيذ البرنامج لاستخراج أخطاء التنفيذ عن طريق تنفيذه خطوة بخطوة باستخدام الأمر Tn حيث n هي عدد الأوامر المطلوب تنفيذها. فمثلا T1 ستنفذ خطوة واحدة من البرنامج ، وهكذا . تذكر هنا أيضا أن مؤشر الأوامر IP لابد أن يحتوى عنوان الخطوة المراد تنفيذها منسوبا لمسجل التجزيء CS . بعد تنفيذ كل خطوة يظهر الديبجر محتويات جميع المسجلات وكذلك الأموالتالي في التنفيذ كما يلي :

C:\TASM>debug example2.exe

r-

AX=0000 BX=0000 CX=001E DX=0000 SP=0100 BP=0000 SI=0000 DI=0000 DS=1898 ES=1898 SS=18AA CS=18A8 IP=0000 NVUP EI PL NZ NA PO NC 18A8:0000 B400 MOV AH,00

t1-

AX=0000 BX=0000 CX=001E DX=0000 SP=0100 BP=0000 SI=0000 DI=0000 DS=1898 ES=1898 SS=18AA CS=18A8 IP=0002 NVUP EI PL NZ NA PO NC 18A8:0002 B001 MOV AL,01

t1-

AX=0001 BX=0000 CX=001E DX=0000 SP=0100 BP=0000 SI=0000 DI=0000 DS=1898 ES=1898 SS=18AA CS=18A8 IP=0004 NVUP EI PL NZ NA PO NC 18A8;0004 B702 MOV BH,02

t2-

AX=0001 BX=0200 CX=001E DX=0000 SP=0100 BP=0000 SI=0000 DI=0000 DS=1898 ES=1898 SS=18AA CS=18A8 IP=0006 NVUP EI PL NZ NA PO NC 18A8:0006 B303 MOV BL,03

AX=0001 BX=0203 CX=001E DX=0000 SP=0100 BP=0000 SI=0000 DI=0000 DS=1898 ES=1898 SS=18AA CS=18A8 IP=0008 NVUP EI PL NZ NA PO NC 18A8:0008 B504 MOV CH,04

### 6-6-15 تغيير محتويات عنوان في الذاكرة Ea

فى الكثير من الأحيان يتطلب تنفيذ البرنامج وضع قيمة معينة فى عنوان محدد فى الذاكرة . يتم ذلك بالأمر Ea حيث a هدى عنوان البايت المراد تغيير محتوياتها ، حيث بعد كتابة هذا الأمر يعرض الديبجر محتويات هذا العنوان الموجودة فعليا وينتظر منك تغيير هذه القيمة .

## <u>0 -6-15</u> الخروج من الديبجر

بكتابة الحرف Q ثم enter تخرج من الديبجر إلى دوس . حاول كتابة مثال 1 الخاص بالإزاحة الدورانية لمحتويات المسجلات وجرب عليه كل أوامر الديبجر .

### 7-15 تـمــاريــن

- أشرح ما هو المقصود بالعنونة الضمنية ؟
  - 2. ما هو المقصود بعنونة المسجلات ؟
- 3. أكتب باختصار عن الديبجر ؟ وماذا تفعل لكي تتبع تتفيذ البرنامج خطوة بخطوة ؟
- 4. أكتب برنامج يحمل المسجلين AH, AL بأي بيانسات بسم يقسوم البرنسامج باستبدال محتويات هذين المسجلين دون فقد محتويات أي مسجل منهما؟
  - 5. أعد التمرين السابق ولكن على مسجلين 16 بت ، AX, BX مثلا ؟
- 7. تتبع تنفيذ البرنامج التالي مع كتابة محتويات المسجلات بعد تنفيذ كل خطــوة
   باعتبار أن جميع المسجلات تحتوى أصفار في بداية البرنامج:

|           | ÃΗ  | AL         | BH              | BL | CH       | CL | DH | DL |
|-----------|-----|------------|-----------------|----|----------|----|----|----|
|           | 00  | 00         | 00              | 00 | 00       | 00 | 00 | 00 |
| MOV AL,05 |     |            | -               |    |          |    |    |    |
| MOV AH,01 |     |            |                 |    |          |    |    |    |
| MOV BX,AX |     |            |                 |    |          |    |    |    |
| MOV CL,BH |     |            |                 | ₩. | per lang |    |    |    |
| MOV CH,BL |     |            | <b>9</b> 46.649 |    |          |    | -  |    |
| MOV DX,CX | ••• | - tem però |                 |    |          |    | -  |    |

## 8-15 أو امر القفز Jump Instructions

القاعدة العامة أن المعالج يقوم بتنفيذ البرنامج حسب ترتيب الأوامر من أول البرنامج حتى نهايته ، ولقد راعينا ذلك في الأمثلة السابقة . ولكن هناك بعض التطبيقات التي تتطلب الخروج على هذه القاعدة ، كأن يطلب منك متسلا تنفيذ عملية معينة أو مجموعة من الأوامر عدد معين من المسرات أو حتى عدد لا نهائي من المرات . لقد أتاح المعالج ذلك بتوفير بعض الأوامسر التي تمكنك كمبرمج من القفز بعملية التنفيذ من مكان الآخر خلال البرنامج ، عادة تنقسم أوامر القفز إلى نوعين كالتالى :

### 1-8-15 القفز غير المشروط Unconditional jump

عند تنفيذ أو امر القفز غير المشروط ينتقل المعالج بعملية التنفيد إلى المكان الجديد والمحدد دون قيد أو شرط . هذا المكان الذى سيتم القفز إليه يكون محددا بعلامة معينة label حيث تستخدم هذه العلامة في أمر القفز كذلك . هناك أمر وحيد للقفز غير المشروط وهو الأمر :

jmp label

كمثال على ذلك ما يلى:

again: mov ax,05H mov bx,ax mov cx,bx jmp again

حيث العلامة again تم استخدامها قبل الأمر mov ax,05H المراد القفر إليه ، كما تم استخدامها أيضا في أمر القفر نفسه . من شروط العلامات المستخدمة أنها لابد أن تبدأ بحرف أبجدي ومن الممكن أن تحتوى أرقاما ومن الممكن أن يصل عدد حروف العلامة إلى 31 حرفا . يجب أيضا ألا تحتوى العلامة على مسافات ، ويجب أن تتهي بالحرف ":" كدليل يبين نهاية العلامة . كذلك لابد من وجود مسافة بين نهاية العلامة ":" وبداية الأمر .

#### 2-8-15 القفز المشروط Conditional jump

كما يوحي الاسم فإن هذا النوع من القفز لن يتم إلا إذا تحقق شرطا معينا ، إذا لم يتحقق هذا الشرط فإن القفز لن يتم وسيستمر البرنامج في مساره الطبيعي حيت ينفذ الأمر التالي لأمر القفز . إن شروط القفز توضع دائما على الأعلام ، فهناك

قفز مثلا إذا كانت النتيجة تساوى صفرا ، أى أن علم الصفر يساوى واحد ، كما أن هناك قفزا إذا كان هناك حملا فى آخر عملية قام بها المعالج ، وهكذا . جدول (51-2) يبين معظم أوامر القفز الشهيرة والكثيرة الاستخدام مع المعالج 8086/8088 . هناك أيضا أوامر قفز مشروطة بحالة معينة لأكثر من علم مثل الأمر JA والذى يعنى اقفز إذا كانت النتيجة أكبر من الصفر ، وتكون النتيجة أكبر من الصفر ، وتكون النتيجة أكبر من الصفر إذا كان علم الصفر يساوى صفرا وعلم الإشارة يساوى صفرا أيضا .

|        | وصــف الأمــــــــــــــــــــــــــــــــــــ   |
|--------|--------------------------------------------------|
| ا امسر | وهــــــــــــــــــــــــــــــــــــ           |
| القفز  |                                                  |
| JA     | اقفز إذا كانت النتيجة فوق الصفر jump if above    |
| JAE    | اقفز إذا كانت النتيجة فوق الصفر أو تساوى صفر     |
| JB     | اقفل إذا كانت النتيجة تحت الصفر jump if below    |
| JBE    | اقفز إذا كانت النتيجة تحت الصفر أو تساويه        |
| JE/JZ  | اقفز إذا كانت النتيجة تساوى الصفر jump if equal  |
| JNC    | jump if no carry اقفز إذا لم يكن هناك حمل        |
| JNE    | اقفز إذا كانت النتيجة لا تساوى الصفر             |
| JNO    | اقفز إذا لم يكن هناك فيضان في النتيجة            |
| JPO    | اقفز إذا كانت الباريتي فردية jump if parity odd  |
| JNS    | أقفز إذا كانت النتيجة موجبة jump if no sign      |
| JO     | اقفز إذا كان هناك فيضان في النتيجة               |
| JРЕ    | أقفز إذا كانت الباريتي زوجية jump if parity even |
| JS     | اقفز إذا كانت النتيجة سالبة jump if sign         |
| JG     | jump if greater النتيجة أكبر من الصفر            |
| JGE    | اقفز إذا كانت النتيجة أكبر من الصفر أو تساويه    |
| ЛL     | اقفز إذا كانت النتيجة أقل من الصفر jump if less  |
| JLE    | اقفز إذا كانت النتيجة أقل من أو تساوى            |
| JCXZ   | اقفر إذا كان المسجل CX=0 يساوى صفر               |

جدول (15–2) أوامر القفز المشروط

#### مثال 15-3

أكتب برنامجا يقارن محتويات المسجل AX والمسجل BX بحيث إذا كانسا متساويان يضع 1 في المسجل DX ، أما إذا كانا غير متساويين فيضع صفر في المسجل DX هذا مع الحفاظ على محتويات كل من المسجلين DX و DX .

أحد الاقتراحات لهذا البرنامج هو البرنامج التالي مع العلم أنه مــن الممكـن أن يكون هناك أكثر من حل بالذات بعد أن ندرس باقى أوامر الحساب .

MOV CX,AX SUB AX,BX

JZ HERE1

MOV DX,0

JMP HERE2

HERE1: MOV DX,1 HERE2: MOV AX,CX

نلاحظ أن هذا البرنامج قد احتفظ بمحتويات المسجل AX في المسجل CX كمسا في الأمر الأول ، بعد ذلك طرح محتويات المسجل BX من المسجل AX حيث ستوضع النتيجة في المسجل AX ، لذلك فإن محتويات المسجل AX متفقد ولذلك فقد احتفظنا بها في المسجل CX ، بعد ذلك إذا كانت نتيجة الطرح صفرا فإن المسجلين متساويين وسيضع البرنامج 1 في المسجل DX بعد أن يقفر إلى العلامة HERE1 . أما إذا كان المسجلين غير متساويين فسيضع البرنامج صفر في المسجل DX ثم يقفز إلى العلامة HERE2 ليسترد محتويات المسجل AX من المسجل CX .

### 3-8-15 الأمر LOOP

من الأوامر الكثيرة الاستخدام لعمل الحلقات الأمر LOOP والذى ينفذ مجموعة الأوامر المحصورة بينه وبين العلامة المذكورة فيه عدد من المسرات يساوى محتويات المسجل CX. كمثال على ذلك انظر إلى ما يلي:

MOV CX,10H HERE: MOV AX,00H

......

LOOP HERE

حيث سينفذ هذا البرنامج مجموعة الأوامر الموجودة بين الأمر LOOP والعلامة HERE1 عدد 16 (10H) مرة حيث هذا العدد مخزن في المسجل CX قبل الدخول في البرنامج .

## 9-15 أول خطوات التعامل مع الذاكرة First step to memory addressing

هناك طريقتان للتعامل مع الذاكرة وهما كما يلي :

### 1-9-15 الطريقة المباشرة Direct addressing

فى هذه الطريقة يوجد العنوان المراد التعامل معه فى الأمسر نفسه مباشرة ، ولذلك سميت هذه الطريقة بالطريقة المباشرة للتعامل مع الذاكرة . كمثال على ذلك الأوامر التالية :

MOV al,[2000H]

وهذا الأمر يعنى نقل محتويات البايت أو العنوان 2000H في الذاكرة إلى المسجل al .

#### MOV AX,[2000H]

.  $\overrightarrow{AX}$  والذي يعنى نقل محتويات العنوان 2000H والذي يليه إلى المسجل  $\overrightarrow{AX}$  MOV [31F2H], AL

والذى يعنى نقل محتويات المسجل AL إلى البايت التى عنوانها 31F2H . نلاحظ أنه فى كل هذه الأوامر ظهر العنوان مباشرة فى الأمر نفسه ، ونلاحظ أيضا أن العنوان تم وضعه بين القوسين المربعين [] .

من الممكن أن يرمز للعنوان برمز معين كما في الأمر التالي :

MOV AL, table

والذى يعنى نقل محتويات البايت المسماة بالاسم table إلى المسجل AL . إن جميع العناوين المباشرة تكون دائما محددة في مقطع أو جزء البيانات . أي أن العنوان 2000H مثلا يحسب ابتداء من العنوان الموجود في مسجل التجزيء DS.

## 2-9-15 الطريقة غير المباشرة Indirect addressing

هذه الطريقة من العنونة كما ذكرنا في الفصل الثاني تسمح بالتعامل مع بيانات موجودة في الذاكرة حيث العنوان الذي سيتم التعامل معه في هذه الحالة يكون موجودا في أحد مسجلات المعالج التالية: BX, BP, SI, DI . كمثال على ذلك افترض أن المسجل BX يحتوى الرقم 1000H وطلبنا من المعالج تنفيذ الأمر التالي: MOV AX,[BX] . في هذه الحالة سيقوم المعالج بإحضار نسخة من محتويات العنوان 1000H (والذي يليه) الموجود في المسجل BX ويضعها فك المسجل AX . أي أن محتويات المسجل BX الموضوع بين قوسين مربعين كما رأينا تمثل عنوان المعلومة وليس المعلومة نفسها ، ففي عدم وجود القوسين

سينسخ المعالج محتويات المسجل BX ويضعها في المسجل AX كما رأينا فسي أول طرق العنونة (عنونة المسجل) . يجب أن نؤكد هنسا أن العنون الفعلي للمعلومة يحسب منسوبا لمحتويات مسجل التجزيء DS بعد إزاحته ناحية اليسلر 4 بتات كما ذكرنا سالفا ، أي أنه إذا كانت محتويات المسجل 01000+000 فسإن الأمر السابق سينسخ محتويات العنوان العنوان المسجل BX, SI, DI والمندى يايه ويضعها في المسجل AX . لاحظ أيضا أن المسجلات BBX, SI, DI تعنون عناوين منسوبة إلى مسجل التجزيء DS بينما المسجل BP يعنون عناوين منسوبة لمسجل التجزيء SS . شكل (15-3) عبارة عن رسم توضيحي لعمليسة العنونة غير المباشرة للذاكرة . كأمثلة على هذا النوع من العنونة أيضا انظر إلى الأوامر التالية :



MOV CX,[BX] MOV [BP],BL MOV [DI],AH MOV [DI],[BX] (خطأ

حيث الأمر الأول سينقل محتويات عنوان (والذي يليه) في جيز البيانيات أو ذاكرة البيانات المسجل BX والمشار إليه بالمسجل BX إلى المسجل حينما الأمر الثاني سينقل محتويات النصف الأول من المسجل BX إلى عنوان مشار إليه بالمسجل BP ويقع في جزء المكدسة . الأمر الثالث سينقل النصف العلوي من المسجل AX إلى عنوان مشار إليه بالمسجل DI ويقع في جزء المينانات ، أما الأمر الثالث فغير مسموح به لأنه ينقل من ذاكرة إلى ذاكرة وهذا

النوع من العنونة غير مسموح به إلا في حالات خاصة جدا مع بعصض أوامر سلاسل الحروف .

# أوامر الحساب 10-15 أوامر الحساب

أو امر الحساب التي يمكن تتفيذها بلغة الأسمبلي هي الجمع والطرح والضرب والقسمة . كل هذه العمليات يمكن إجراؤها على بيانات 8 بت أو 16بت .

# ADD أمر الجمع ADD الصورة العامة لهذا الأمر هي:

ADD destination, source



حيث في هذا الأمر يتم جمع المصدر source مع الهدف destination وتوضيع النتيجة في الهدف . من أمثلة ذلك ما يلي :

ADD AX,BX

هذا الأمر يجمع محتويات المسجل BX مع محتويات المسجل AX ويضع النتيجة في المسجل AX ، لاحظ أن هذا الأمر يجمع مسجلين كل منهما 16بت . شكل (15-4) يبين رسما توضيحا لهذا الأمر . أمثلة أخرى على هذا الأمر ما يلي :

ADD Al,CL

الذى يجمع محتويات النصف الأول من المسجل CX مسع النصف الأول من المسجل AL وبضع النتيجة في المسجل AL .

ADD AL,[BX]

الذى يجمع محتويات مكان الذاكرة (8بت) الذى عنوانه فى المسحجل BX مع محتويات المسجل AL .

ADD AX.0F437H

هذا الأمر يجمع الثابت أو القيمة الفورية F437H (16بـت) مـع المسـجل AX ويضع النتيجة في المسجل AX . في العادة يتم وضع 0 قبـل أي ثـابت يبـدأ بحرف وكذلك وضع الحرف H في نهاية الثابت للدلالة على أنــه فـي النظـام الستعشري .

ADD table, 20H

الذى يجمع الثابت 20H مع محتويات مكان الذاكرة المسمى table ويضع النتيجة في نفس المكان . المكان المسمى table تتم تسميته بهذا الاسم في مقطع البيانات في بداية البرنامج باستخدام أمر التوجيه define . كمثال على ذلك الأمر التالى :

• table DB 22H

هذا الأمر التوجيهي يحجز بايت اسمها table ويعطيها القيمة الابتدائية 22 -

• table DB 22H, 25H, 'A', 33H

هذا الأمر يحجز عدد 5 بايت ويعطيها القيم الابتدائية السابقة ، وهدذه الخمسة أماكن تأخذ الاسم table . هناك أيضا الأوامر DW الذي يحجز كلمة word ، والأمر DD الذي يحجز 4 كلمات ، والأمر DD الذي يحجز 4 كلمات ، والأمر DT الذي يحجز 10 كلمات . في جميع هذه الأوامر الاسم الملحق بالأمر يمثل عنوان أول بايت في كمية الذاكرة المحجوزة .

من الأشياء المهمة التي يجب ألا تنسى هي أنه لا يمكن جمع مكان ذاكرة علي مكان ذاكرة المار مكان ذاكرة آخر . فمثلا الأمر التالي خطأ في عرف لغة الأسمبلي :

ADD [BX],[3F20H]

لأنه يحاول جمع محتويات العنوان 3F20H مع محتويات العنوان المورجود في المسجل BX وهذا خطأ أو غير مسموح .

# <u>2-10-15 أمر الجمع ADC</u>

الصورة العامة لهذا الأمر هي:

ADC destination, source

حيث في هذا الأمر يتم جمع المصدر source مع الهدف destination مع محتويات علم الحمل carry flag والتي تكون صفرا أو واحد ، وتوضع النتيجة في الهدف . من أمثلة ذلك ما يلي :

#### ADC AX,BX

هذا الأمر يجمع محتويات المسجل BX مع محتويات المسجل AX مع محتويات علم الحمل ويضع النتيجة في المسجل AX . لاحظ أن هذا الأمر يجمع مسجلين كل منهما 16بت مع علم الحمل . شكل (-15) يبين رسما توضيحا لهذا الأمر ما يلي :

ADC AL,CL ADC BL, table ADC CL,40H ADC BX, [SI]



كل هذه الأوامر تجمع محتويات المصدر مع الهدف مع علم الحمل وتضع النتيجة في الهدف . هنا يظهر سؤال مهم عن الفرق بين الأمرين ADC و ADC . لكي نفهم الفرق بينهما نسوق المثال التالى :

#### مثال <u>15 -4</u>

اكتب برنامجا يجمع الرقمين 3F246718 و 4A78B451 ويضسع النتيجة في المسجلات PX و PX و PX و PX المسجلات PX و PX منهما PX و PX منهما PX و PX و PX و PX و PX الأول من الرقم الثاني (B451) مع المسجل PX و P

الثاني (4A78) مع المسجل CX باستخدام الأمر ADC حتى يتم أخذ علم الحمل في الاعتبار لأنه قد يكون هناك حمل من عملية الجمع الأولى فيجب أخده في الاعتبار . شكل(15-6) يبين رسما توضيحيا لهذا المثال . لاحظ أن عملية الجمع الأولى يجب أن تتم باستخدام الأمر ADC وليس باستخدام الأمر ADC لأنه لدو استخدم الأمر ADC فسيجمع علم الحمل من عملية سابقة مما سيؤثر على النتيجة ويجعلها خطأ .



البرنامج الذي سيقوم بعملية الجمع السابقة من الممكن أن يكون كالتالى :

ADD BX,0B451H

ADC CX,4A78H

MOV DX,00H

ADC DX,DX

### 3-10-15 أمر الطرح SUB

هناك أمران للطرح مثل الجمع ، أحدهما لا يأخذ علم الحمل في الاعتبار والآخو يأخذ علم الحمل في الاعتبار . الأمر SUB يطرح محتويات المصدر من محتويات الهدف ويضع النتيجة في الهدف ، فمثلا الأمر :

#### SUB AX,BX

سيطرح المسجل BX (المصدر) من المسجل AX (الهدف) ويضع النتيجة فى المسجل AX . نؤكد هنا على أن الهدف يكون هو دائما المطروح منه . أمثلة أخرى على أو امر الطرح كالتالي :

SUB DL,CL ; DL-CL  $\longrightarrow$  DL SUB AL,[BX] ; AL-[BX]  $\longrightarrow$  AL SUB BL,20H ; BL-20  $\longrightarrow$  BL

### SBB مر الطرح SBB

هنا يتم طرح المصدر وعلم الحمل CF من الهدف وتوضع النتيجة في السهدف. من أمثلة ذلك ما يلي:

SBB AX,BX; AX-BX-CF  $\longrightarrow$  AX SBB DL,CL; DL-CL-CF  $\longrightarrow$  DL SBB AL,[BX]; AL-[BX]-CF  $\longrightarrow$  AL SBB BL,20H; BL-20-CF  $\longrightarrow$  BL

يجب أن نكون حذرين جدا في الأماكن التي نستخدم فيها الأمر SUB والأماكن الأخرى التي يجب أن نستخدم فيها الأمر SBB لأن ذلك من الممكن أن يعطي نتيجة خاطئة كما أوضحنا مع أوامر الجمع .

#### 5-10-15 أمر المقارنة CMP

من الأوامر الشهيرة الاستخدام في الكثير من التطبيقات أمر المقارنة CMP الذي له الصورة العامة التالية:

#### CMP destination, source

حيث يتم طرح المصدر source من الهدف destination ولكن هذا لا يتم وضع النتيجة في الهدف ولكن يبقى الهدف دون تغيير ، وهذا هو الاختلاف الأساسي بين هذا الأمر وأوامر الطرح السابقة . الاستفادة الوحيدة من تتفيذ هذا الأمر هي تأثر الأعلام بنتيجة هذا الطرح . بالطبع ما أكثر التطبيقات التسي نحتاج فيها لمقارنة رقمين لمعرفة أيهما أكبر من الآخر مثلا دون تغيير قيمة أى واحد مسن الرقمين حيث في هذه الحالة فإن أوامر الطرح السابقة لا تسؤدي هذا الغرض مباشرة ، لذلك في هذه الأحوال نستخدم الأمر CMP .

### 6-10-15 الأوامر INC و DEC

تعمل هذه الأوامر على زيادة محتويات المصدر أو إنقاصــها بمقـدار واحـد . الصورة العامة لهذين الأمرين هي كالتالي :

INC source DEC source

ومن أمثلة ذلك ما يلى:

INC BL INC CX INC [SI] DEC DL DEC [BX]

وجميعها تجمع 1 أو تطرح 1 من محتويات المصدر الموجود في الأمسر سسواء كان مسجل (8 أو 16 بت) أو بايت ذاكرة .

#### مثال 15-<u>5</u>

أكتب برنامجا يقوم بضرب محتويات المسجلين CL و يضع النتيجة في المسجل AX وذلك عن طريق الجمع المتكرر .

MOV AL,00
MOV AL,CL
DCR BL
YY: ADD AL,CL
JNC XX
INC AH
XX: DCR BL
JNZ YY

HLT

#### <u>مثال 15-6</u>

أكتب برنامجا يقسم محتويات المسجل AL على محتويات المسجل CL ويضـع النتيجة في المسجل AH والباقي في المسجل DL وذلك عـن طريـق الطـرح المتكرر .

MOV AH,00 CMP AL.CL

JS XX; CL>AL put AL into DL as a remainder

and stop

YY: SUB AL,CL

JS XX1 INC AH JMP YY

XX1: ADD AL,CL

XX: MOV DL, AL; put remainder in DL.

HLT

# 7-10-15 أمر الضرب MUL

الصورة العامة لهذا الأمر هي :

MUL source

حيث يقوم هذا الأمر بضرب المصدر source الذي يكون مسجلا (8 بـــت أو 16 بين) أو بايت ذاكرة في المسجل AL وذلك إذا كان المصدر 8 بت ، أما إذا كان المصدر 16 بت فإنه يضرب المصدر في المسجل AX . أي أن الطرف التـاني لعملية الضرب يكون دائما إما المسجل AL أو المسجل AX على حسـب عـدد بتات المصدر . إذا كان المصدر 8 بت فإن الطرف الثاني لعملية الضرب يكـون المسجل AL كما ذكرنا وتوضع النتيجة في المسجل AL و AH حيث يحتـوي كان المصدر 16 بت فإن الطرف الثاني لعملية الضرب يكون المسجل AX كمـا كان المصدر 16 بت فإن الطرف الثاني لعملية الضرب يكون المسجل AX كمـا ذكرنا ، ولكن النتيجة في هذه المرة توضع في المسجلين AX (الـذي يحتـوي للجزء الأدنى من النتيجة) و XX الذي يحتوى الجزء الأعلى منها . بالطبع فـان الجزء الأدنى من النتيجة) و XX الذي يحتوى الجزء الأعلى منها . بالطبع فـان حميع الأعلام تتأثر بهذه العملية . من أمثلة ذلك ما يلى :

MUL BL

الذى يضرب محتويات المسجل BL في المسجل AL ويضع النتيجة في المسجل AX .

MUL CX

الذي يضرب محتويات المسجلين CX و AX ويضع النتيجة في المسجلين AX و DX .

MUL [BX]

الذى يضرب محتويات بايت الذاكرة المشار إليها بالعنوان الموجود في المسجل BX في المسجل AX .

من الأشياء المهمة التي يجب أن نحذرها أو نتجنبها هي ضسرب قيمة فورية (ثابت) في المسجل AL أو AX على الصورة التالية:

MUL 05 MUL 3f24

MUL 3f24

فى هذه الحالة يجب أن نضع الثابت فى أى مسجل أو لا ثم نستخدم هذا المسجل فى عملية الضرب.

# 10-15 أمر القسمة DIV أمر القسمة المرادة العامة لهذا الأمر هي:

DIV source

حيث يقوم هذا الأمر بقسمة المسجل AX أو المسجلين AX و DX على المصدر source الذي يكون مسجلا (8 بت أو 16 بت) أو بايت ذاكرة . أى أن المصدر يكون دائما هو المقسوم عليه . أما المقسوم فيتحدد على حسب المصدر كالتالي : 1. إذا كان المصدر 8 بت فإن المقسوم لابد أن تكون بتاته ضعف بتات المقسوم عليه ولذلك فإنه يكون المسجل AX في هذه الحالة . وفي هذه الحالمة يخزن خارج القسمة في المسجل AL والباقي من عملية القسمة في المسجل AH .

2. إذا كان المصدر 16 بت فإن المقسوم يكون المسجلين AX و DX حيث AX يحتوى النصف الأدنى و DX يحتوى النصف الأعلى للمقسوم . أما ناتج القسمة فإنه يوضع في المسجل AX والباقي من القسمة فإنه يوضع في المسجل DX . من أمثلة عمليات القسمة ما يلى :

#### DIV BL

الذى يقسم محتويات المسجل AX على المسجل BL ويضع النتيجة في المسجل AL والباقي في المسجل AH والباقي في المسجل

#### DIV CX

الذي يقسم محتويات المسجلين AX و DX على المسجل CX ويضع النتيجة في المسجل AX والباقي في المسجل DX .

#### DIV [BX]

الذى يقسم محتويات المسجل AX على بايت الذاكرة المشار إليها بالعنوان الموجود في المسجل BX والباقي في المسجل AL والباقي في المسجل AH

من الأشياء المهمة التي يجب أن نحذرها أو نتجنبها هي استخدام قيمـــة فوريـة (ثابت) في عملية قسمة كالتالي:



فى هذه الحالة يمكن أن يوضع الثابت فى أى مسجل ثم يستخدم هذا المسجل في

## مثال 15-7

أكتب برنامجا يحسب مضروب الرقم الموجود في عنوان الذاكرة 1800H ويضع نتيجة هذا المضروب في المسجل AX .

MOV AX, 01
MOV BL,[1800]
MOV BH,00
MOV CX,BX
DEC CX
XX: MUL BL
DEC BL
LOOP XX
HLT

## 11-15 أوامر المنطق Logic Instructions

هذه المجموعة خاصة بإجراء العمليات المنطقية ، ويقصد بالعملية المنطقية العملية المنطقية التسى يجريسها العملية التي معاملاتها هي الواحد أو الصفر . العمليات المنطقية التسي يجريسها المعالج 8088 هي عمليات AND, OR, XOR, NOT .

# AND الأمر AND الصورة العامة لهذا الأمر هي:

AND destination, source

حيث يتم إجراء عملية AND على كل من المصدر source والهدف وتوضع النتيجة في الهدف destination . بالطبع فإن كل من المصدر والمهدف لابد أن يكونا نفس الحجم أى لهما نفس العدد من البتات . من أمثلة ذلك ما يلي : AND AL.BL

حيث يجرى عملية AND على محتويات المسجلين AL, BL ويضع النتيجة فـــى المسجل AL . فمثلا افترض أن المسجلين AL, BL يحتويان البيانات التالية :

BL = 101111101 = BDHAL = 11101110 = EEH

فإنه بعد تنفيذ الأمر AND AL,BL ستكون محتوياتهما كالتالى :



AND CX,DX AND BH table AND CH,11011011B

حيث الأمر الأخير سيجرى عملية AND على المسجل CH والمعلومة الفورية أو الثابت 11011011B المعطى في الصورة الثنائية والتي تم الإشارة إليها باستخدام الحرف B في آخر الثابت وحيث تسمح لغة التجميع بذلك .

# OR الأمر OR الأمر OR الأمر المام المام المام المام المامة المام ا

OR destination, source

حيث يتم إجراء عملية OR على كل من المصدر source والهدف OR وتوضع النتيجة في الهدف destination . بالطبع فإن كل من المصدر والمهدف لابد أن يكونا نفس الحجم أي لهما نفس العدد من البتات . من أمثلة ذلك ما يلي : OR AL, BL

حيث يجرى عملية OR على محتويات المسجلين AL, BL ويضع النتيجــة فــى المسحل AL

OR CX,DX

OR BH,table OR CH,11011011B

## 3-11-15 الأمر XOR

الصورة العامة لهذا الأمر هي:

XOR destination, source

حيث يتم إجراء عملية XOR على كل من المصدر والهدف وتوضع النتيجة في الهدف . من أمثلة ذلك ما يلى :

XOR AL, BL

حيث يجرى عملية XOR على محتويات المسجلين AL, BL ويضع النتيجة فــى المسجل AL. BL

XOR CX,DX XOR BH,table XOR CH,11011011B

### NOT أمر النفي المنطقى NOT

هذا الأمر له معامل واحد والصورة العامة له هي كالتالي :

NOT source

حيث يتم عكس المصدر عكسا منطقيا بجعل كل صفر واحد وكل واحدد صفر وبالطبع فإن نتيجة هذا العكس توضع في نفس المصدر . من أمثلة ذلك ما يلى :

NOT AL

**NOT DX** 

NOT [BX]

## 12-15 أوامر الإزاحة والدوران Shift And Rotate Instructions

هناك نوعان من الإزاحة ، إزاحة حسابية وهي التي يتم الاحتفاظ فيها بإشارة الرقم الذي تجرى علية الإزاحة وبالذات إذا كانت الإزاحة ناحية اليمين كما سنرى . أما الإزاحة المنطقية فلا اعتبار فيها للإشارة .

## 12-15 أمر الإزاحة الحسابية لليمين SAR

يتم هذا إزاحة محتويات كل خانة إلى الخانة التى على يمينها ، وأما الخانة التسى يتم هذا إزاحة محتويات كل خانة اليسار فيتم ملأها دائما بمحتويات خانة الإشارة والتى هسى نفس محتويات الخانة الأخيرة . أى أن محتويات آخر بست ناحيسة اليسسار يتسم

الاحتفاظ بها دائما ولا تفرغ . أما محتويات البت في أقصى اليمين فتذهب إلى علم الحمل . شكل (15-7) يبين رسما توضيحيا لهذا الأمر والصورة العامة لـــه ستكون كالتالى :



SAR destination, count

حيث count أن تكون واحد إذا كانت الإزاحة ستتم مرة واحدة فقط وأمـــا إذا أردنا الإزاحة أكثر من مرة فيوضع عدد المرات في المسجل CL شــم يسـتخدم المسجل CL بدلا من count في الصورة العامة للأمر . كمثال على ذلك نفترض أن المسجل AL = 10011010 بعد تنفيذ الأمر AL = AL فإن محتويات المسجل AL وعلم الحمل ستكون كالتالى :

$$AL = 10011010$$
 $AL = 11001101$ ,  $CF = 0$ 

## 2-12-15 أمز الإزاحة الحسابية للبسار SAL

يتم هنا إزاحة محتويات كل خانة إلى الخانة التي على يسارها ، وأما الخانة التي يتم تفريغها في أقصى اليمين فيتم ملاها بأصفار . أما محتويات البت في أقصى اليسار فتذهب إلى علم الحمل . شكل (15-8) يبين رسما توضيحيا لهذا الأمر والصورة العامة له ستكون كالتالي :

SAL destination, count

حيث count إما أن تكون واحد إذا كانت الإزاحة ستتم مرة واحدة فقط وأمـــا إذا أردنا الإزاحة أكثر من مرة فيوضع عدد المرات في المسجل CL تـــم يســتخدم المسجل CL بدلا من count في الصورة العامة للأمر . كمثال على ذلك نفترض

أن المسجل AL= 10011010 بعد تنفيذ الأمر SAL AL,1 فإن محتويات المسجل AL وعلم الحمل ستكون كالتالى:



$$AL = 10011010$$
 $AL = 00110100 CF = 1$ 

#### SHR أمر الازاحة المنطقية لليمين

يتم هذا إزاحة محتويات كل خانة إلى الخانة التي على يمينها ، وآخر خانة ناحية اليسار يتم ملأها دائما بصفر مع كل إزاحة . أما محتويات البيت في أقصى اليمين فتذهب إلى علم الحمل . شكل (15-9) يبين رسما توضيحيا لهذا الأمر والصورة العامة له ستكون كالتالى :

#### SHR destination, count

حيث count إما أن تكون واحد إذا كانت الإزاحة ستتم مرة واحدة فقط وأما إذا أردنا الإزاحة أكثر من مرة فيوضع عدد المرات في المسجل  $\rm CL$  شمر مرة فيوضع عدد المرات في المسجل  $\rm CL$  بدلا من count في الصورة العامة للأمر . كمثال على ذلك نفترض أن محتويات المسجل هي  $\rm AL$  = 10011010 ، بعد تنفيذ الأمر  $\rm SHR$   $\rm AL$  فان محتويات المسجل  $\rm AL$  وعلم الحمل ستكون كالتالى :



$$AL = 10011010$$
 $AL = 01001101$ ,  $CF = 0$ 

## 5HL أمر الازاحة المنطقية لليسار

يتم هذا إزاحة محتويات كل خانة إلى الخانة التى على يسارها ، وأما الخانة التى يتم تفريغها فى أقصى اليمين فيتم ملأها بأصفار . أما محتويات البت فى أقصى اليمين فيتم ملأها بأصفار . أما محتويات البت فى أقصى اليسار فتذهب إلى علم الحمل تماما مثل الأمر SAL. شكل (15–10) يبين رسما توضيحيا لهذا الأمر والصورة العامة له ستكون كالتالى :

SHL destination, count

حيث count إما أن تكون واحد إذا كانت الإزاحة ستتم مرة واحدة فقط وأما إذا أردنا الإزاحة أكثر من مرة فيوضع عدد المرات في المسجل CL تسم يستخدم المسجل CL بدلا من count في الصورة العامة للأمر . كمثال على ذلك نفترض أن المسجل AL = 10011010 عبد تنفيذ الأمر AL = 10011010 فإن محتويات المسجل AL = 10011010

$$AL = 10011010$$
 $AL = 00110100 \leftarrow 0$   $CF = 1$ 



### 80R أمر الدور ان لليمين FOR

أو امر الدوران تشبه أو امر الإزاحة تماما فيما عدا أن المحتويات التى تزاح مىن أى جهة يتم إدخالها مرة أخرى من الجهة الأخرى . شكل ( $10^{-1}$ ) يبين رسما توضيحيا لأمر الدوران لليمين والصورة العامة له ستكون كالتالى :



ROR destination, count

حيث count هي كما شرحنا في الأوامر السابقة تماما . كمثال على ذلك نفسترض أن المسجل AL = 10011010 على بعد تتفيذ الأمر AL = 10011010 فإن محتويات المسجل AL

$$AL = 10011010$$
 $AL = 01001101$ ,  $CF = 0$ 

## 12-15 أمر الدوران لليسار ROL

شكل (15-12) يبين رسما توضيحيا لهذا الأمر والصورة العامــة لـه سـتكون كالتالى:

ROL destination, count

كمثال على ذلك نفترض أن المسجل AL = 10011010 = AL حيث بعد تنفيد الأمر ROL AL, 1 فإن محتويات المسجل AL وعلم الحمل ستكون كالتالى:



RCR أمر الدوران لليمين من خلال علم الحمل RCR شكل (15–13) يبين رسما توضيحيا لأمر الدوران لليمين من خلال علم الحمل والصورة العامة له ستكون كالتالى:

RCR destination, count

حيث count هي كما شرحنا في الأوامر السابقة تماما . كمثال على ذلك نفترض أن المسجل AL = 10011010 بعد تتفيذ الأمر RCR AL,1 فإن محتويات المسجل AL وعلم الحمل ستكون كالتالي بافتراض أن علم الحمل كان فيه واحد قبل تتفييذ الأمر :



$$AL = 10011010$$
  $CF = 1$ 
 $AL = 11001101$ ,  $CF = 0$ 

8-12-15 أمر الدور ان لليسيار من خلال علم الحمل RCL شكل (15-8 أمر الدور ان اليسيار من خلال علم العامية ليه المستكون شكل (15-14) يبين رسما توضيحيا لهذا الأمر والصورة العامية ليه سيتكون كالتالي :

RCL destination, count

كمثال على ذلك نفترض أن المسجل AL = 10011010 = AL حيث بعد تتفيــــذ الأمــر RCL AL,1 فإن محتويات المسجل AL وعلم الحمل ستكون كالتالي بــافتراض أن علم الحمل كان واحدا قبل تنفيذ الأمر:



$$AL = 10011010$$
  $CF = 1$ 
 $AL = 0011010$   $CF = 1$ 

#### مثال 15-8

أكتب برنامج يحسب مضروب الأرقام المخزنة في الذاكرة من 1800H إلى 1810H ويخزن المضروب في الأماكن 1900H إلى 1910H . استخدم الببرامج الفرعية معتبرا أن قيمة المضروب لن تزيد عن بايت واحدة .

MOV DI,1800

MOV SI,1900

MOV CX,10H

MOV BH,00

XX: MOV BL,[DI]

PUSH CX

CALL FACT

POP CX

MOV [SI],AL

INC SI

MOV [SI],AH

INC SI

INC DI LOOP XX HLT

FACT: MOV AL,01

MOV CX,BX

DEC CX

YY: MUL BL

DEC BL

LOOP YY

RET

#### 13-15 تسماريسان

- 1. هل يمكن جمع المسجلين CX و DS
- 2. إذا كان المسجل CX=1001H والمسجل DX=20FFH فما هي محتويات كل من المسجلين وكذلك قيمة كل علم من الأعلام بعد تتفيد أمر الجمع ADD عليهما؟
  - 3. كرر السؤال السابق في حالة تتفيذ أمر الطرح SUB ؟
- 4. كرر السؤال الثاني في حالة إجراء الأوامر التاليـــة AND و OR و XOR و NOT
- أكتب برنامج يضع صفرا في جميع أماكن الذاكرة 2000H إلى 20FFH ،
   وبعد ذلك يختبر نفس الأماكن ليرى إذا كان الصفر ما زال موجودا أم لا ؟ هــل يصلح هذا ليكون بمثابة اختبار لذاكرة الحاسب ؟
- 6. اكتب برنامج ينسخ محتويات بلوك الذاكرة 2000H إلى 20FFH في البلوك الذاكرة 3000H إلى 30FFH في البلوك
- 7. أكتب برنامجا يختبر محتويات أماكن الذاكرة 1800H إلى 18FFH ويخرج منها الأعداد الفردية ويخزنها في الذاكرة من 1900H إلى 19FFH والأعداد الزوجية يخزنها في الذاكرة من 2000H إلى 20FFH .
- 8. اكتب برنامج يفحص محتويات الذاكرة من 2000H إلى 2500H ويبحث فيها عن عدد مرات تكرار الرقم 33H المكون من بايت واحدة؟
- 9. اكتب برنامج يفحص محتويات الذاكرة من 2000H إلى 2500H ويبحث فيها عن عدد مرات تكرار الرقم 33FFH المكون من 2 بايت؟
- 10. أكتب برنامجا يحسب عدد الوحايد في كل بايت من بايتات الذاكرة من 100H إلى 19FFH .

- 11. أعد السؤال السابق مستخدما البرامج الفرعية .
- 12. أكتب برنامجا يحسب مضروب الأرقام الموجودة في الذاكرة من 1800H إلى 18FFH ويخزن هذا المضروب في الذاكرة من 1900H إلى 19FFH . استخدم البرامج الفرعية .
- 13. أكتب برنامج يحسب عدد الأرقام السالبة وعدد الأرقام الموجبة فـــى المــدى العنواني من 18FFH ـ 1800 .
- 14. أكتب برنامج يقرأ محتويات المدى العنوانى 17FFH-1700 ثم ينقل البيانات السالبة منها ويخزنها ابتداء من العنوان 1800H والبيانات الموجبة يخزنها ابتداء من العنوان 1900H.
- 15. أكتب برنامج يحسب عدد الأرقام الفردية وعدد الأرقام الزوجية في المدى العنواني 1761-1700 .
- 16. اكتب برنامج يبحث عن أكبر رقم من بايت واحدة في المدى العنواني 16. اكتب برنامج يبحث عن أكبر رقم من بايت واحدة في المدى العنواني
- 17. اكتب برنامج يقوم بترتيب الأرقام (كل رقم بايت واحدة) الموجودة في المدى العنواني 2000H إلى 200FH ترتيبا تصاعديا؟
- 18. المدى العنواني 2000H إلى 3000H يحتوى بيانات إشارة صوتية ، والمطلوب حساب عدد مرات عبور هذه الإشارة القيمة صفر ؟
  - 19. استخدم البرامج الفرعية في حساب المعادلة التالية:

 $M=20! + 30! + 40! + 24^3 + 25^5 + 10^6$ 

# الفصل السادس عشر

مواجمة المعالج 8086/8088

## 1-16 مــقدمـــة

لقد رأينا في الفصول السابقة كيفية مواجهة الشريحة 8085 مع الذاكرة ومع بوابات الإدخال و الإخراج . إن مواجهة الشريحة 8086 لن تختلف كثيرا عن ذلك وسنحاول تقديمها هنا سريعا من خلال شرح مختصر لوظيفة كل طرف من أطراف هذه الشريحة . ثم شرح عملية فصل المسارات المختلفة ، مسار العناوين ومسار البيانات ومسار التحكم .

## 2-16 الوظائف المختلفة لأطراف الشريحة 8086/8088

كل من الشريحتين 8086 أو 8088 لها 40 طرفا وهذه هي آخر أجيال شرائح المعالجات التي لها هذا العدد من الأطرف حيث كما سنرى في المعالجات القادمة أن عدد الأطراف قد قفز قفزة كبيرة . الاختلاف بين وظائف أطراف الشريحة 8086 و الشريحة 8088 بسيطا جدا وفي عدد محدود جدا من الأطراف كما سنرى .

قبل أن ندخل في تفاصيل وظائف هذه الأطراف يجب أن نعلم أن كل من الشريحتين تستخدم فكرة المزج الزمني time multiplexing التي سبق شرحها مع الشريحة 8085 بإسهاب ومع الكثير من الأطراف . إن فكرة المزج الزمني كمن سبق وقدمناها تتلخص في أن نفس الطرف يمكن أن يحمل أكثر من إشارة في وقتين مختلفين . فمثلا الطرف ADO يحمل إشارة عناوين وإشارة بيانات أيضل ، فهذا الخط يمثل الإشارة DO عند لحظة معينة ، كما يمثل الإشارة OD عند لحظة أخرى لابد من فصل إشارة المعالج مع أية شريحة أخرى لابد من فصل إشارة البيانات على خط منفصل وإشارة العناوين على خط آخر . تتم عملية الفصل باستخدام الطرف ALE الذي يكون واحدا عندما تكون الإشارة على الطرف ADO مثلا تمثل عناوين ، ويكون صفرا عندما تكون الإشارة على هذا الخط تمثل بيانات .

هنا نرجو من القارئ أن يراجع الفصل الخاص بفصل أو عزل مسارات الشريحة 8085 عيث أنها هي نفسها بالضبط المستخدمة مع الشريحة 8086/8088 . شكل (16-1) يبين رسما طرفيا لكل من الشريحتين 8086/8088 حيث يمكن عرض وظائف هذه الأطراف كما يلي: 1. الخطوط AD0 إلى AD7 تحمل مزيج من إشارة العناوين و البيانسات حيث تكون الإشارة على هذه الأطراف عناوين عندما يكون الطرف ALE فعسال أي واحد ، وتكون بيانات عندما يكون الطرف ALE غير فعال أي صفر. هذا الكلام مطبق على كل من الشريحتين 8086 أو 8088 .

| ][        |        |       |            | 0.10     |       |          | l       |
|-----------|--------|-------|------------|----------|-------|----------|---------|
| GND       | I      | 40    | Vcc        | GND      | 1     |          | Vcc     |
| AD14      | 2      | 39    | AD15       | A14      | 2     | 39       | A15     |
| AD13      | 3      | 38    | A16/S3     | A13      | 3     | 38       | A16/S3  |
| AD12      | 4      | 37    | A17/\$4    | Al2      | 4     | . 37     | A17/S4  |
| AD11      | 5      | 36    | A18/S5     | Al1      | 5     | 36       | A18/S5  |
| AD10      | 6      | 35    | A19/S6     | A10      | 6     | 35       | A19/S6  |
| AD9       | 7      | 34    | BHE/S7     | A9       | 7     | 34       | 330     |
| AD8       | 8      | 33    | MN/MX      | A8       | 8     | 33       | MN/MX   |
| AD7       | 9      | 32    | RD         | AD7      | 9     | 32       | RD      |
| ADd       | 10     | 31    | HOLD       | AD6      | 10    | 31       | HOLD    |
| AD5       | 11     | 30    | HOLDA      | AD5      | 11    | 30       | HLDA    |
| AD4       | 12     | 29    | WR         | AD4      | 12    | 29       | WR      |
| AD3       | 13     | 28    | M/ĨO       | AD3      | 13    | 28       | IO/M    |
| AD2       |        | 27    | DT/R       | AD2      | 14    | 27       | DT/R    |
| ADI       | 15     | 26    | DEN        | AD1      | 15    | 26       | DEN     |
| ADd       | 1      | 25    | ALE        | AD0      | 16    | 25       | ALE     |
| NMI       | 17     | 24    | INTA       | NMI      | 17    | 24       | INTA    |
| INTR      | 18     | 23    | TEST       | INTR     | 18    | 23       | TEST    |
| CLK       | 19     | 22    | READY      | CLK      | 19    | 22       | READY   |
| GND       | 20     | 21    | RESET      | GND      | l .   | 21       | RESET   |
|           |        |       |            | (        |       |          |         |
| 808       | بحة 86 | الشر  | <b>-</b> Í | 80       | 88 Ã  | الشريد   | -ب      |
| 311-11 :  | 8086   | /ହ∩ହହ | للمعالجين  | الطر ة   |       | JI /1-1. | 6) (K:: |
| قی الحالہ | 0000   |       | . سيسس     | المعارسي | رسم   |          | 0,000   |
|           | • Mi   | nimur | ی n mode   | ِ الصنغر | پة او | الحقيف   |         |
| 1         |        |       |            |          |       |          |         |
|           |        |       |            |          |       |          |         |

2. الخطوط AD8 إلى AD15 ، في حالة الشريحة 8088 تسمى هذه الأطراف AB-A15 حيث أنها في هذه الحالة تحمل إشارة عناوين فقط طول الوقت وليسس هناك أي مزج زمني في الإشارات لأن مسار البيانسات في هذه الشريحة 8086 فإن مسار خطوط فقط وينتهي عند الطرف AD7 . أما في حالة الشريحة 8086 فإن مسار البيانات يكون 16 طرفا ، لذلك فإن الخطوط AD8-AD15 تحميل مزيجا من إشارة البيانات يكون 18 إلى D15 وإشارة العناوين A8 إلى AL5 حيث تكون الإشارة على هذه الخطوط إشارة عناوين عندما يكون الطرف ALE فعالا (1) ، وتكون على هذه الخطوط إشارة عناوين عندما يكون الطرف ALE فعالا (1) ، وتكون

الإشارة بيانات عندما يكون الطرف ALE غير فعال (0) كما في حالة الخطوط AD0-AD7 .

3. الأطراف A16/S3 و A17/S4 و A18/S5 و A19/S6 تحمل إشارة عنساوين للخطوط A16-A19 حينما يكون الخط ALE فعالاً . عندما يكون الخطط ALE غير فعال فإن هذه الخطوط تحمل الإشارات S3, S4, S5, S6 التي تمثل حالات مختلفة للمعالج . حيث الطرف S6 يكون صفرا دائما ، والطرف S5 يبين حالة علم المقاطعة ، والطرفين S3, S4 يبينان أي مقطع من الذاكرة يتم التعامل مع الذاكرة كما في جدول 1-16 .

| S4 | S3 | الوظيــــفة   |
|----|----|---------------|
| 0  | 0  | Extra segment |
| 0  | 1  | Stack segment |
| 1  | 0  | Code          |
| 1  | 1  | Data          |

جدول 16-1

4. الطرف RD هذا الطرف يكون فعالا (0) حينما يكون المعالج في حالة قسراءة للبيانات سواء من الذاكرة أو من بوابة إدخال . أي أن البيانات الموجودة على مسار البيانات تكون داخلة المعالج و لا يهم من أي مصدر تكون هذه البيانات .

5. الطرف READY . لكي يقوم المعالج بنتفيذ أي أمر ، لابد وأن يكون هذا الطرف فعالا (1) . إذا أصبح هذا الخط صفرا فإن المعالج يدخل في حالة انتظار ، حيث تتجمد جميع أطراف المعالج على الحالة التي كان عليها ، ويستفاد بذلك عند مواجهة المعالج مع بعض الأجهزة الخارجية البطيئة مثل بعض شرائح الذاكرة البطيئة أو أجهزة الإدخال والإخراج مثل الطابعات والتي لا تضاهى سرعتها سرعة المعالج .

6. الطرف INTR ، حينما يكون هذا الطرف فعالا (1) تتم مقاطعة المعالج ، حيث يكمل تتفيذ الأمر المشغول به ثم يذهب لتنفيذ برنامج معين لخدمة هذه المقاطعة ، وبعد الانتهاء من هذه الخدمة يرجع المعالج إلي نفس مكان البرنامج الأساسى الذي تمت عنده المقاطعة .

7. الطرف TEST ، الأمر WAIT والذي يمثل حالة انتظار يدخل المعالج فيها ويظل فيها طالما أن الخط TEST غير فعال (1) . عندما يصبح هذا الخط فعالا (0) فإن المعالج يخرج من حالة الانتظار ويستمر في تنفيذ البرنامج الأساسيي . حالة الانتظار هنا يتم الدخول فيها بالأمر WAIT على العكس من حالة الانتظار

التي يتم الدخول فيها بجعل الخط READY صفرا ، حيث تتسهي هذه الحالة برجوع الخط READY واحد مرة أخرى .

8. الطرف NMI ، وهو طرف المقاطعة الغير قابلة للحجب أو غير المقنعة ، حيث تتم مقاطعة المعالج هنا بانتقال الخط NMI من الصفر إلي الواحد (أي عند الحافة الصناعدة) ، ولايهم هنا أن يكون علم المقاطعة يساوي واحد ، وتوضع على هذا الطرف إشارات المقاطعة المهمة مثل إشارات انقطاع القدرة مثلا .

9. الطرف RESET ، أو إعادة الوضع ، حيث عندما يكون هذا الطرف واحد فإن المعالج يذهب فورا إلى عنوان الذاكرة FFF0H ويبدأ التنفيذ من هناك . وفي العادة يكون عند هذا العنوان أمر قفز إلى مكان آخر في الذاكرة يحتوي شفرة برنامج خاص بإعادة الوضع للمعالج .

10. الطّرف CLK يتم إدخال نبضات التزامن من على هذا الطرف بالتردد المطلوب و duty cycle أو زمن ON/OFF بنسبة 33% حتى نضمن الستزامن المطلوب لجميع العمليات التي ينفذها المعالج.

11. الطرف Vcc حيث يوضع جهد القدرة الثابت %Vc -/+ 5V +/-

12. الطرف GND وهما طرفان يجب أن يكونا متصلين بباقي أطراف الأرضيي في النظام الخارجي .

MN/MX ، وهو طرف الحالة حيث عندما يكون هذا الطرف (1) فإن المعالج يعمل في الحالة الصغرى Minimum ، وإذا كان هذا الطرف (0) فإن المعالج يعمل في الحالة العظمى Maximum . الحالة الصغرى هي الحالة العادية للمعالج 8086 ، وأما الحالة العظمى فهي حالة المعالج عندما يتعامل مع معالج العمليات الحسابية 8087 .

14. الطرف BHE/S7 يستخدم هذا الخط لتنشيط البايت ذات القيمة العظمي من مسار البيانات . هذه الإشارة تمستزج مسار البيانات . هذه الإشارة تمستزج مع إشارة الحالة S7 . هذا الطرف بالطبع موجود فقط في المعالج 8086 السذي يتعامل على أساس أن البيانات الخارجية 16 بت .

10. الطرف IO/M في المعالج 8088 هذا الطرف يبين ما إذا كانت الإشارة الموجودة على مسار العناوين تمثل عنوان في ذاكرة أم عنوان لوحدة إدخال أو إخراج . هذا الخطيكون (1) إذا كانت الإشارة تمثل عنوان في وحدة إدخال أو إخراج و يكون (0) إذا كانت الإشارة تمثل عنوان في ذاكرة . لاحظ وجود شرطة على الحرف M في اسم هذا الطرف . في حالة المعالج 8086 تكون الإشارة على هذا الطرف معكوسة ورمز الخط في هذه الحالة هو M/IO .

16. الطرف  $\overline{WR}$  مثل الطرف  $\overline{RD}$  يكون فعالا (0) في حالة كتابــة بيانــات فــي الذاكرة أو أي وحدة إخراج .

- 17. الطرف INTR ، عند الاستجابة لطلب المقاطعة على الطرف INTR ، فــــإن المعالج يجعل الخط INTR فعالا (٥) للدلالة على أنه قبل المقاطعة واعترف بــها وينتظر إدخال رقم المقاطعة التي سيقوم بخدمتها على مسار البيانات .
- 18. الطرف ALE ، وهو خط مسك العنوا ن ALE يستخدم للدلالة على أن الإشارة الموجودة على الخطوط ADO-AD15 تمثل عنوين أم بيانات . عندما يكون هذا الخط واحد فإن الإشارة على هذه الخطوط تمثل عنوان وعندما يكون الخط ALE صفرا فإن الإشارة على هذه الخطوط تمثل بيانات . يستخدم هذا الخط الفصل إشارة العناوين عن البيانات كما سنرى .
- 19. الخط DT/R ، خط إرسال أو استقبال البيانات حيث يستخدم هذا الخط لبيانات إذا كانت البيانات خارجة Transmit, T أو داخلة Receive, R المعالج . لذلك فإن هذا الخط سيستخدم لتحديد اتجاه البيانات عند فصل مسار البيانات كما سنرى.
- 20. الطرف DEN ، طرف تتشيط مسار البيانات DEN ، حيث يستخدم هذا الطرف لبيان إذا كانت الخطوط ADO-AD15 تحمل إشارة بيانات الخطوط دقيقية أم لا .
- 2. الطرف HOLD ، عندما يكون هذا الطرف فعالا (1) فإن المعالج يضع كلل مساراته (البيانات ، والعناوين ، والتحكم) في الحالة الثالثية ، حالة المقاومة العالية ، أو بمعنى آخر فإن المعالج ينفصل عن كل المسارات الخارجية تاركا إياها في العادة لمتحكم الاتصال المباشر بالذاكرة لاستخدامها في نقلل البيانات مباشرة للذاكرة .
- 22. الطرف HLDA ، خط استجابة للطرف HOLD ويستخدمه المعالج للدلالة على أنه قبل الإشارة HOLD وأنه قد تم الانفصال عن جميع المسارات حيث عند ذلك يقوم المعالج بوضع (1) على هذا الخط .
- 23. الطرف  $\overline{SSO}$  في الشريحة 8088 عبارة عن طرف حالة حيث يستخدم مع الأطراف  $\overline{SO}$  الأطراف  $\overline{SO}$  و  $\overline{SO}$  لبيان حالة المعالج في أثناء أي دورة مسار Bus . cycle . جدول 2-16 يبين هذه الحالات .
- 24. الأطراف S0, S1, S2 عبارة عن أطراف حالة تبين حالة المعالج في أثناء أي دورة مسارات وتستخدم هذه الخطوط في الحالة العظمى للمعالج فقط Maximum . جدول (16-3) يبين هذه الحالات ، لاحظ التشابه الموجود بينها وبين حدول 16-2 .
- 25. الأطراف RQ/GTO, RQ/GTT تستخدم هذه الخطوط لطلب المسارات عن طريق المعالج الحسابي المساعد Math coprocessor الخارجي في الحالة العظمي فقط maximum mode . كل من هذه الخطوط ثنائي الاتجاه حيث عليها يطلب المعالج المساعد المسارات ، وعليها أيضا يستجيب المعالج ليخبر المعالج

الخارجي بأن المسارات متاحة . هذه الخطوط ممزوجة مع الإشارات HOLD و HOLDA .

| IO/M | DT/R | SSO | الوظيفة                         |
|------|------|-----|---------------------------------|
| 0    | 0    | 0   | حالة اعتراف بالمقاطعة Interrupt |
|      |      |     | acknowledge                     |
| 0    | 0    | 1   | قراءة من الذاكرة Memory read    |
| 0    | 1    | 0   | كتابة في الذاكرة Memory write   |
| 0    | 1    | 1   | توقف Halt                       |
| 1    | 0    | 0   | تعامل مع شفرة أمر Code access   |
| 1    | 0    | 1   | قراءة من بوابة إدخال I/O read   |
| 1    | 1    | 0   | كتابة في بوابة إخراج I/O write  |
| 1    | 1    | 1   | حالة خمول Remains passive       |

جدول 16-2

| <u>S2</u> | <u>S1</u> |   | الوظيـــفة                      |
|-----------|-----------|---|---------------------------------|
| 0         | 0         | 0 | حالة اعتراف بالمقاطعة Interrupt |
|           |           |   | acknowledge                     |
| 0         | 0         | 1 | قراءة من بوابة إدخال I/O read   |
| 0         | 1         | 0 | كتابة في بوابة إخراج I/O write  |
| 0         | 1         | 1 | توقف Halt                       |
| 1         | 0         | 0 | تعامل مع شفرة أمر Code access   |
| 1         | 0         | 1 | قراءة من الذاكرة Memory read    |
| 1         | 1         | 0 | كتابة في الذاكرة Memory write   |
| 1         | 1         | 1 | حالة خمول Remains passive       |

جدول 16-3

26. الطرف LOCK ، يستخدم في الحالة العظمي فقط (طرف 29) ، حينما يكون هذا الطرف فعالا (0) يمنع أي معالج خارجي من الاتصال بالمسارات . بعصض الأوامر تستفيد بهذا الخط حتى تضمن اكتمال تتفيذها دون أي تدخل من المعالجات الخارجية .

27. الأطراف QSO-QS1 (الأطراف 25و 24) عبارة عن خطوط حالة تبين حالسة الطابور Queue الموجود في وحدة مواجهة المسارات لبيان إذا كان هذا الطابور فارغ أو ممثلئ . لاحظ أن هذا الطابور يتكون من 6 بايت في حالمة المعالج 8086 و 4 بايت في حالة المعالج 8088 . هذه الخطوط فعالة في الحالة العظمي

## 1-2-16 نبضات الساعة clock للمعالج 8086

كما رأينا سابقا فإنه لابد من إدخال نبضات ساعة مربعة الشكل سابقة التجهيز إلى الطرف CLK وهو الطرف رقم 19 في الشريحة . تصردد هذه النبضات حوالي 5 ميجاهرتز ، و النسبة الدورية لها 33% . هذه النبضات يتم تزامن جميع عمليات المعالج معها . لقد تم إنتاج شريحة بواسطة شركة Intel تعطى هذه النبضات بالمواصفات المطلوبة للمعالج 8086 كما أنها تأخذ الإشارة من المستخدم وتقدمها للمعالج بالمواصفات و التزامن المطلوب ، وكذلك الإشارة من المستخدم وتقدمها للمعالج بالمواصفات و التزامن المطلوب ، وكذلك الإشارة X2 و X2 يوصل عليها بالورة crystal بالتردد المناسب ، كما يوصل عليها المفتاح X2 يوصل عليها بالورة المناسب ، كما يوصل عليها الشريحة كما في شكل (16-2) . بالطبع ليس بالضرورة استخدام الشريحة 8284A النات ولكن يمكن استخدام أي مولد ذبذبات بالمواصفات المطلوبة ، ولكن يفضل استخدامها بالذات تجنبا للكثير من المشاكل وتوفير الكثير من المكونات التي قد تكون مضطرا لاستخدامها .

## 3-16 عزل مسارات المعالج 8086

إن عملية عزل (فصل) مسارات المعالج 8086 هي نفسها تماما عملية عالى مسارات المعالج 8085 حيث أن كل من المعالجين يستخدم فكرة المزج الزمني المسارى البيانات والعناوين. لذلك فإننا نحيل القارئ هنا لمراجعة عملية فصل كل من مسار العناوين والبيانات للشريحة 8085 والتي سبق شرحها. شكل (16-3) يبين كيفية فصل مسارى العناوين والبيانات وبعض خطوط التحكم للشاريحة 8086. نلاحظ من هذا الشكل استخدام شالات شرائح 74373 لمسك إشارة العناوين في الفترة التي يكون فيها الطرف ALE فعالا (1). لاحظ اتصال هذا الطرف بالثلاث شرائح، أما الطرف OE لكل شريحة فتم توصيله بالأرضى حتى يكون خرج هذه الشرائح فعالا دائما. بذلك نضمن مسك إشارة خطوط العناوين في نفس الشكل المعنوين في الشارة البيانات. نلاحظ أيضا في نفس الشكل

استخدام شريحتين 74245 للحصول على إشارة البيانات . الشريحة 74245 كما نعلم ثنائية الاتجاه ولذلك فإن اتجاه البيانات فيها تم التحكم فيه باستخدام الطروف DT/R الذي تم توصيله على خط التحكم في الاتجاه DIR في الشريحة 74245 بذلك نضمن مرور البيانات في الاتجاه السليم حسب خروجها من المعالج . لابد أيضا أن تكون الشريحة 74245 فعالة فقط أثناء وجود إشارة بيانات محققة على الأطراف DEN لذي يكون فعالا (٥) كما ذكرنا من قبل عند وجود بيانات محققة على هذه الأطراف . لذلك تصم توصيل الطرف DEN بالطرف CS للشريحة 74245 .



لقد تم استخدام الشريحة 74244 لفصل بعض خطوط التحكم مثل الخطوط  $\overline{\text{IO/M}}$  .  $\overline{\text{RD}}$  ,  $\overline{\text{RD}}$  ,  $\overline{\text{WR}}$  ,  $\overline{\text{exis}}$  ,  $\overline{\text{exis}}$  .  $\overline{\text{exis}}$  الخطوط عيل عمل حساب الأحمال التي ستوصل على هذه الخطوط .

# 4-16 مواجهة الشريحة 8086/8088 مع الذاكرة

المعالج 8088 له مسار بيانات 8 بت ومسار عناوين 20 بت ، وعلى ذلك فإنه المعالج التعامل مع ذاكرة مقدارها 1 ميجابايت . و تتم مواجهته مع هذه الذاكرة

بنفس الطريقة التي درسناها مع أي معالج من المعالجات 8 بت التي سبق در استها ، وننصح هنا بمراجعة القصل الخاص بمواجهة الذاكرة .



كما رأينا فإن شرائح الذاكرة القابلة للقراءة فقط ROM يكون لها خطي تحكم في العادة وهما الخط  $\overline{CS}$  أو أحيانا يسمى  $\overline{CE}$  وهو خط اختيار الشريحة Chip أو خط تنشيط الشريحة Chip حيث لابد أن يكون هذا الطرف

فعالا (0) حتى تعمل هذه الشريحة . هذا الطرف يوصل في العادة بخرج مشفر العناوين Address Decoder الذي نضمن به أن هذه الشريحة ان تعمل إلا في حالة وجود عنوان يقع ضمن المدى العنواني لهذه الشريحة والمحدد بمشفر العناوين . خط التحكم الثاني في شرائح ROM هو الخط  $\overline{OE}$  والذي عندما يكون فعالا يسمح بخروج البيانات المطلوب قراءتها على مسار البيانات لهذه الشريحة وبالتالي يستطيع المعالج قراءتها . هذا الطرف  $\overline{OE}$  يوصل في العادة بالإشسارة  $\overline{MEMR}$  والذي يكون فعالا عندما يكون كلا من الخطين  $\overline{RD}$  و  $\overline{MOM}$  صفرا . شكل (16-4) يبين كيفية توصيل شرائح ROM على المعالج . بالنسبة لشرائح  $\overline{CE}$  أو  $\overline{CE}$  كما ذكرنا سابقا ، وثانيها يكون الخط  $\overline{OE}$  كما هو موجود في شرائح  $\overline{CE}$  كما ذكرنا سابقا ، وثانيها يكون الخط  $\overline{MEM}$  أو خط تنشيط الكتابة  $\overline{CE}$  المستقل  $\overline{CE}$  أو  $\overline{CE}$  كما في المخون أن يكون فعالا عند التسجيل أو الكتابة في شريحة  $\overline{CE}$  هذا الخط يوصل عادة بخط التحكم  $\overline{MEMW}$  المكون من الخطين  $\overline{MEM}$  و  $\overline{MEMW}$  القادمان من المعالج . شكل (16-4ب) يبين ذلك .

إن مواجهة المعالج 8086 تختلف كثيرا عن مواجهة المعاليج 8088 وكل المعالجات السابقة ، حيث أن المعالج 8086 يكون مسار البيانات فيه 16بت ، ويكون هناك أو امر تتعامل مع هذا المسار على أساس 16 بت وأو امسر أخرى تتعامل مع مسار البيانات على أساس 8 بت ، لذلك فإن عملية المواجهة هنا يجب أن تأخذ ذلك في الحسبان ، مسار العناوين للمعالج 8086 يتكون من 20 بست و لذلك فإنه سيتعامل مع ذاكرة مقدارها 1 ميجابايت إذا كان سيتعامل على مستوى البايت ، أما إذا تعامل على مستوى 16بت (الكلمة) فإنه سيتعامل مع نصف هذه الكمية ، أي نصف ميجاوورد أو 512 كيلوورد . يتم ذلك بسالطبع من خلل توصيلة خاصة للذاكرة مع كل من مساري البيانات والعناوين .

المعالج 8086 ينظر الذاكرة على أنها مقسمة نصفين أو بنكين . البنك الأول هـو مجموعة البيانات ذات العناوين الزوجية ، والبنك الثاني هو مجموعـة البيانات ذات العناوين الزوجية ، والبنك الثاني هو مجموعـة البيانات ذات العناوين الفردية كما في شكل (16-5) . البنك الأول أو الزوجـي يسمى البنك الأدنى D0-D7 لأنه يحمل نصف المعلومة الأدنى ح0-D0 ، ويتـم تنشيط هذا النصف باستخدام خط العناوين A0 الذي يكون صفرا عند التعامل مع أي عنوان زوجي حيث أن أي رقم زوجي تكون أول بت فيه تساوي صفرا . أملا البنك الأعلى من المعلومة D8-D15 فيتم تخزينه في البنك الأعلى مـن الذاكـرة المناك الأعلى من المعلومة كالتحكم BHE الذي يكـون فعـالا (0) عنـد التعامل مع أي بايت في البنك العلوي . إذن معنى ذلك أن الخـط A0 سـيكون صفرا في حالة التعامل مع النصف الأدنى من الذاكرة على أساس 8 بت فقـط ، ويكون أيضا صفرا في حالة التعامل مع الذاكرة على أساس 16 بت . أما الخـط

 $\overline{BHE}$  فيكون فعالا (0) في حالة التعامل مع البنك الأعلى من الذاكرة على أساس 8 بت ، أو التعامل مع الذاكرة على أساس 16بت .





شكل (16-6) يبين كيفية استخدام مشفرين العناوين التعامل مع ذاكرة مقدار هـ 1 ميجابايت مقسمة إلي نصفين زوجي وفردي ، وكل نصف مكون من 8 شـ رائح كل منها 64 كيلوبايت . لاحظ ان كل من المشفرين تم توصيل خطوط التحكم لهم كل منها 64 كيلوبايت . لاحظ ان كل من المشفرين تم توصيل خطوط التحكم لهم A, B, C على خطوط العناوين A17, A18, A19 على التوالي . أما خط التنشيط E3 في كل من المشفرين يتم توصيله على الخط 8088 التي يكون فيها هـ ذا الخط التعامل مع الذاكرة على العكس من الشريحة 8088 التي يكون فيها هـ ذا الخط صفرا عند التعامل مع الذاكرة ، ولذلك فإن هذا الخط يرمز له بالرمز IO/M في حالة الشريحة 8088 . أما خط التحكم  $\overline{E}$  فتم توصيله بالأرضي في الشريحتين على فعالا دائما ، وأما خط التحكم  $\overline{E}$  في المشفر الأول فمتصل بخط العناوين على الخط  $\overline{E}$  في المشفر الأول فمتصل بخط العناوين على الخط  $\overline{E}$  في المشفر الأنهي الذي يختار النصف الأعلى أو الفردي مـن الذاكرة . لذلك فإنه عند التعامل مع الذاكرة على أساس 16 بت فإن كل مـن A0 و  $\overline{E}$  في نفس الوقت حيث  $\overline{E}$  في نفس الوقت حيث يتم قراءة أو كتابة البيانات على مسار البيانات بالكامل 10-D1 .

أماً عند التعامل مع أحد النصفين الزوجي أو الفردي فإنه إما أن يكون الخط A0 فعالا (0) أو يكون الخط BHE فعالا (0) وبذلك نضمن التعامل مع أحد النصفين في حالة التعامل على أساس 8 بت.

في شكل (16-6) نلاحظ أن الخط A0 تم توصيله كخط تتشيط لمشفر النصف الزوجي من الذاكرة ، ثم بعد ذلك تم توصيل الخط A1 من المعالج بالخط A0 في الذاكرة ، و الخط A2 من المعالج بالخط A1 في الذاكرة ، و بذلك نضمن التعامل مع كل بايت في الذاكرة في حالة التعامل على أساس 8 بايت ؛ أي سيتم استخدام مع كل بايت في الذاكرة في حالة التعامل على أساس 8 بايت ؛ أي سيتم استخدام من المعالج على الذاكرة وفي نفس الوقت نستخدمه على التوازي من المعالج على الخط A0 في الذاكرة وفي نفس الوقت نستخدمه على التوازي لتتشيط المشفر وباقي خطوط العناوين يتم توصيلها كل مع ما يناظره . حاول أن بتخيل هذا التوصيل وتابع عملية التعامل مع عناوين الذاكرة ابتداء من العنوان العنوان 2000 ثم العنوان العنوان المعالم مع نصف كمية الذاكرة فقط في بايت وتترك الأخرى مما يعني أن التعامل سيتم مع نصف كمية الذاكرة فقط ولن يمكن استخدام النصف الآخر منها ، ولذلك يجب تجنب استخدام هذه الطريقة للتوصيل .



6-16 الإدخال والإخراج من وإلي المعالج 8086/8088

لقد سبق أشرح عملية الإدخال و الإخراج من وإلي المعالجات Z80 و 8085 في فصل سابق ورأينا أن هناك طريقتان للإدخال و الإخراج . الطريقة الأولى هـي باستخدام الأمرين IN وOUT وسميت هذه الطريقة بطريقة الإدخال والإخـــراج

المباشر ، كما أن هناك طريقة أخرى للإدخال والإخراج وهي استعمال عنساوين الذاكرة في ذلك ، وهذا ما أسميناه بطريقة خرائط الذاكرة للإدخال والإخسراج . كلا الطريقتين سنستخدمهم أيضا مع المعالج 8086 ولذلك ننصح بمراجعة هذا الفصل بالكامل ، لأننا سنبنى على ما به من معلومات .

## 1-5-16 أو إمر الإنخال و الإخراج للمعالج 8086/8088

جدول 16-4 يبين جميع الحالات الممكنة لأوامر الإدخال والإخراج للمعالج 8086/8088 نلاحظ من هذا الجدول ما يلى:

- عنوان أي بوابة من الممكن أن يكون 8 بت أو 16 بت بحيث عندما يكون العنوان 16بت فإنه يوضع في المسجل DX . أما إذا كان العنوان 8 بست فإنه يوضع مباشرة في الأمر ، فمثلا الأمر IN AL,DX سوف يقرأ محتويات البوابة التي عنوانها موجودا في السجل DX (16بت) ويضعها في السجل AL . يمكن أيضا قراءة بوابة مكونة من 16بت كما في الأمر IN AX,0005 حيث سيقرأ البوابة رقم 2000 المكونة من 16بت ويضعها في المسجل AX (16بست) بالطبع فإن الأوامر التي تتعامل مع بوابات 16بت ستكون محققة فقط مع المعللج بالطبع فإن الأوامر التي تتعامل مع بوابات 16بت كما نعلم .
- الأمر IN AX,DX سيقرأ محتويات البوابة المكونة من 16 بنت والني يوجد عنوانها في المسجل DX ويضع هذه المحتويات في المسجل AX. لاحظ أنه طالما أن عنوان البوابة مكون من 16 بت فإن ذلك يعني أنه من الممكن التعامل مع 64ك من بوابات الإدخال و الإخراج وهذا كما نرى كم هائل من بوابات الإدخال و الإخراج وهذا كما نرى كم هائل من بوابات الإدخال والإخراج إذا ما قورن بالمعالج 8085 أو المعالج Z80.
- جميع أساسيات الإدخال والإخراج التي درسناها في الفصول السابقة مطبقة هنا من حيث أنه لابد من عملية تشفير لعنوان البوابة ، كما أن عملية إدخال البيانات لابد وأن تكون من خلال عازل Buffer ثلاثي المنطق مثل الشريحة 74374 . عملية تشفير البوابات لابد أن تأخذ في الحسبان الطرف 107M والذي يحدد متى يتعامل المعالج مع بوابات إدخال أو إخراج .

شكل (16–7) يبين مشفر لثمان بوابات ، أربعة منها للإدخال وأربعة للإخراج باستخدام المشفر 74138 هذا المشفر يستخدم مع المعالج 8088 حيث أنه ثمان بتات فقط ، ونلاحظ أن عملية التشفير هنا هي نفسها عملية التشفير التي كنا نستخدمها مع المعالجات 8085 أو Z80 . لأحظ استخدام خطوط التحكم  $\overline{M}$  IO/ $\overline{M}$  و  $\overline{RD}$  و  $\overline{RD}$  و

| الأمــــر | عرض<br>البيانات | تعلــــيق                            |
|-----------|-----------------|--------------------------------------|
| IN AL,d8  | 8               | قراءة بوابة 8 بت عنوانها 8 بت (d8)   |
| IN AL,DX  | 8               | قراءة بوابة 8بت عنوانها في (DX)      |
| IN AX,d8  | 16              | قراءة بوابة 16بت عنوانها 8بت (d8)    |
| IN AX,DX  | 16              | قراءة بوابة 16بت عنوانها في (DX)     |
| OUT d8,AL | 8               | كتابة في بوابة 8بت عنوانها 8بت (d8)  |
| OUT DX,AL | 8               | كتابة في بوابة 8بت عنوانها في (DX)   |
| OUT d8,AX | 16              | كتابة في بوابة 16بت عنوانها 8بت (d8) |
| OUT DX,AX | 16              | كتابة في بوابة 16بت عنوانها في (DX)  |

جدول 16-4



بما أن المعالج 8086 يختلف في طريقة تعامله مع الذاكرة عن المعالج 8088 نتيجة الاختلاف في مسار البيانات فإن هذا ينعكس أيضا على طريقة الإدخال والإخراج للبيانات وبالذات في حالة إدخال أو إخراج بيانات من 8 بن وستكون المشكلة في هذه الحالة هي هل ستستخدم النصف الأدنى من مسار

البيانات أم النصف الأعلى ، أم النصفين معا في حالة إدخال أو إخراج بيانات من 16 بت حيث في هذه الحالة لن تكون هناك أي مشكلة ، المشكلة فقط هي في حالة التعامل مع بيانات وبوابات من 8 بت . إن أسهل الطرق لتجنب هذه المشكلة هي التعامل إما مع النصف الأدنى فقط وفي هذه الحالة نجعل الخط A0 فعالا دائما (0) ؛ أو النصف الأعلى فقط وفي هذه الحالة نجعل الخط BHE فعالا (0) . شكل (16-8أ) يبين ذلك حيث تم استخدام مشفرين 4138 أحدهما يشفر لثمان بوابات بأرقام زوجية ..... F0, F2, F4, والآخر يشفر لثمان بوابات فردية شمان بوابات ذات 16 بست عناوينها هي 18-80 و 83-83 و 85-84 ، ... . لاحظ عدم استخدام الخطين A0 و BHE في عملية التشفير حيث تم الاستغناء عنهما في هذه الحالة . في هذه الحالة مجرد وضع العنوان 80H مثلا سينشط الخرج الأول من المشفر وبالتالي ينشط نصفى البوابة 16 بت الملحقة بهذا الخط معا وفي نفس الوقت .

# 2-5-16 البوابات القابلة للبرمجة PPI

لقد سبق دراسة الشريحة 8255 في فصل سابق و كيفية مواجهتها مع المعالجلت ذات 8 بت والأمر لا يختلف كثيرا هنا ؛ لذا نحيل القارئ لمراجعة هذا الفصل . هناك بعض الشرائح الأخرى القابلة للبرمجة والكثيرة الاستخدام بالذات في مجلل الحاسبات و سنعطي هنا فكرة سريعة عن بعض هذه الشرائح دون الدخول في تفاصيل مواجهة هذه الشرائح . في حالة احتياج القارئ لتفاصيل أكثر عن هدذه الشرائح فإننا نحيله إلى الكتالوجات الخاصة بهذه الشرائح والمراجع الموجودة في آخر الكتاب .

# 6-16 شريحة مواجهة لوحة المفاتيح القابلة للبرمجة 8279

الشريحة 8279 هي شريحة قابلة للبرمجة يمكن بها مواجهة لوحة المفاتيح وكذلك إظهار البيانات التي يتم إدخالها من هذه اللوحة . يمكن توصيل حتى 64 مفتاح على هذه الشريحة ، وتحتوي الشريحة على عازل buffer يمثل طابورا يسمح بتخزين 8 حروف من لوحة المفاتيح ثم استدعاء هذه الحروف على أساس من يصل أولا يخرج أولا عن طريق المعالج . جزء الإظهار يقوم بمسح 16 مكان من أماكن الذاكرة التي تحتوي شفرات البيانات الثمانية المطلوب إظهارها .



# 16-7 المؤقت القابل للبرمجة Programmable Interval Timer, PIT 8254

تحتوي هذه الشريحة على ثلاث عدادات كل منها 16 بت ، وكل منها قابل المبرمجة . كل واحد من هذه العدادات قادر على العد الثنائي أو العدد العشري المبكود ثنائيا BCD وبترددات تصل إلى 10 ميجاهيرتز . يمكن استخدام هذه الشريحة في العديد من التطبيقات مثل الساعة الحقيقية Real time clock عدادات الأشياء ، التحكم في سرعة موتور واتجاهه مثل موتور الأسطوانة الصلبة أو حتى أي موتور ، والكثير من التطبيقات الأخرى التي يكون الزمن فيها عاملا مهما .

إن الحصول على أزمنة تأخير يمكن أن يتم باستخدام بعض أوامر أي لغة من لغات البرمجة ، فمثلا في لغة الأسمبلي يمكن الحصول على زمن تاخير باستخدام حلقة مغلقة كالتالى :

MOV CX.0055H

XX: NOP LOOP XX

حيث سيتم تنفيذ هذه الحلقة عدد من المرات مقداره العدد الموجود في المسحل CX . والمعروف أن كل واحد من هذه الأوامر ينفذ في عدد معين من نبضات الساعة الخاصة بالجهاز ، بحيث يمكن معرفة مقدار زمن التأخير بالضبط بمعرفة تردد إشارة نبضات الساعة الخاصة بالجهاز Clock . من المعووف أن نبضات الساعة Clock تختلف من جهاز لآخر ولذلك فإن زمن التأخير الناتج عن الحلقة السابقة لن يكون ثابتا بأي حال باختلاف جهاز الحاسب الدي تنفذ عليه هذه الحلقة . إن استخدام شرائح التوقيت مثل الشريحة 254 8 يمكن بها الحصول على أزمنة تأخير ثابتة ولن تتوقف على نوع الجهاز الذي تستخدم معه لأنها تعمل على أساس نبضات ساعة ثابتة يتم توصيلها على هذه الشريحة كمسا سنرى .

شكل (16-9أ) يبين رسما صندوقيا لمحتويات هذه الشريحة وشكل (16-9ب) يبين رسما طرفيا لها . الرسم الصندوقي يوضح كيف أن هذه الشريحة مقسمة إلى جزأين أساسيين ، جزءا يواجه المعالج ، ويتكون من ثلاث أجزاء :

الأول : وهو عبارة عن عازل لمسارات البيانات D0 - D7 ويخرج منه 8 أطراف توصل على مسار البيانات (8 بت القادم من المعالج) .

الثاني : ويحتوي خطوط التحكم في القراءة و الكتابة وهي كالتالي :



- الطرف RD الذي يوصل على خط القراءة القادم من المعالج ، حيث عندما يكون هذا الطرف فعالا (0) فإن المعالج يستطيع القراءة من المسجلات الموجودة داخل المؤقت .
- الطرف WR الذي يوصل على خط الكتابة القادم من المعالج ، حيث عندما يكون هذا الخط فعالا (0) فإن المعالج يستطيع كتابة أو إرسال بيانات إلى المسجلات الموجودة داخل المؤقت .
- الطرف CS ، لكي يمكن للمعالج أن يتعامل مع الشريحة PIT في الطرف CS وهو خط اختيار الشريحة Chip Select لابد وأن يكون فعالا (0) , ويكون ذلك بالطبع عن طريق تشفير العنوان الخاص بهذه الشريحة كما رأينا عند التعامل مع الشريحة 8255 .
- الطرفان A0, A1 : هذان الطرفان يوصلان في العادة على خطى العناوين A0, A1 القادمين من المعالج حيث يتم عن طريق هذين الخطين اختيار أحد عدادات الشريحة أو مسجل التحكم داخل الشريحة تبعا للجدول 16-5.

| A1 | A0  | الوظيفة                          |
|----|-----|----------------------------------|
| Ai | 710 | <del></del>                      |
|    |     | (a) # 1 H                        |
| 0  | 0   | العداد رقم (0)                   |
| 0  | 1   | العداد رقم (1)                   |
| 1  | 0   | العداد رقم (1)<br>العداد رقم (2) |
| 1  | 1   | مسجل التحكم                      |

جدول 16-5

الثالث: هو مسجل التحكم Control Register والذي يتم فيه تسجيل كلمة تحكيم Control Register من 8 بتات تمثل اختيار أحد العدادات الثلاثة ليتم التعامل معه حسب حالة تشغيل معينة من خمس حالات تشغيل سنراها بعد قليل.

الجزء الثانى أو الجانب الآخر من الشريحة PIT كما فى شكل (16-19) يمثل الجزء الثانى أو الجانب الموجودة داخل الشريحة ، الجانب المواجه للمستخدم ، وهو يمثل الثلاث عدادات الموجودة داخل الشريحة ، حيث لكل عداد منها ثلاث إشارات أو ثلاثة أطراف كما يلى :

• الأطراف CLKX حيث X تمثل رقم العداد (2, 1, 0) ويتم إدخال نبضات الساعة Clock التي سيقوم العداد بعدها على هذه الأطراف ، ولابد أن يكون تردد هذه النبضات معروفا جيدا ، ويمكن أن يصال هذا التردد حتى 10 ميجاهرتز .

- الأطراف GATEX وكل طرف منها يمثل طرف تتشيط للعداد المراد التعلمل معه Gate Enable .
- الأطراف OUTX وتمثل أطراف خرج للعدادات الثلاثة ، ويمكن برمجة هذه العدادات ليكون الخرج واحدا أو صفرا أو نبضات على حسب حالة التشغيل التي يعمل عليها العداد كما سنرى .
  - آخر طرفان من أطراف الشريحة هما طرفي القدرة GND, Vcc .

|    | )7    | 1  | D6 | D5             | D4       | D3                       | D2       | <b>D</b> 1 |          |   |
|----|-------|----|----|----------------|----------|--------------------------|----------|------------|----------|---|
| SC | 21    | S  | C0 | RW1 RW0        |          | M2                       | Ml       | M          | 0 BCD    | ) |
| S  | C1    | SC | 20 | العداد المختار |          | M2                       | Ml       | МО         | الحالة   |   |
| 0  |       | 0  |    | رقم 0          | عداد     | 0                        | 0        | 0          | الحالة 0 |   |
| 0  |       | 1  |    | رقم 1          | عداد     | 0                        | 0        | 1          | الحالة 1 |   |
| 1  |       | 0  |    | رقم 2          |          | 0                        | 1        | 0          | الحالة 2 |   |
| 1  |       | 1  |    |                | قراءة    | 0                        | 1        | 1          | الحالة 3 |   |
|    | ]     |    |    | حة             | الشري    | 1                        | 0        | 0          | الحالة 4 |   |
|    |       |    |    |                |          | 1                        | 0        | 1          | الحالة 5 |   |
|    | RW    | 1  | RW | 0              |          | اءة/كتابة                | قر       |            |          |   |
| 1  | 0     |    | 0  | _              | ت        | مك العدادا               | ة أمر مه | اءة/كتابا  | قرا      |   |
|    | 0     |    | 1  | نط             |          | ، الأدنى قا              |          |            |          |   |
|    | 1     |    | 0  | أقط            |          | الأعلى ف                 | ة النصف  | ءة/كتابا   | قرا      |   |
|    | 1     |    | 1  |                | م الأعلى | ، الأدنى ث               | ة النصف  | ءة/كتابا   | قرا      |   |
| Γ  | BCD 2 |    |    | طريقة الع      | ·        |                          |          |            |          |   |
| Ī  | 0     |    |    |                |          |                          |          | اد ثنائي   |          |   |
|    | 1     |    |    |                | В        | عداد عشری مکود تثانیا CD |          |            |          |   |

### 1-7-16 يرمجة الشريحة 8254

كما رأينا فإن الشريحة 8254 تحتوى ثلاث عدادات كل منها 16 بت ، أى يمكن لكل منها أن يعد من 0 إلى FFFFH في خالة العد الثنائي ، أو العد من 0 إلى

9999 في حالة العد العشرى . يمكن اختيار أى واحد من العدادات الثلاثة ، وطريقة التعامل معه ، وكذلك حالة التعامل عن طريق شفرة توضع في مسجل التحكم . شكل (16–10) يبين مسجل التحكم ودلالة كل بست من بتات هذا المسجل. يحتوى شكل (16–10) أيضا على جداول توضح وظيفة كل مجموعة من مجموعات البتات في هذا المسجل كما يلى :

- البتات D6 و D7 تمثل شفرات اختيار أحد العدادات Select Counter bits ليتم التعامل معه ، أو قراءة حالة الشريحة . فإذا كان كل من بنت 6 و 7 تساوى صفر فإن المقصود في هذه الحالة هو التعامل مع العداد رقسم صفر ، أما إذا كانت بت 6 تساوى واحد ، وبت 7 تساوى صفر ، فإن التعامل في هذه الحالة سيكون مع العداد رقم واحد ، وهكذا . أما إذا كان كل من بنت 6 و 7 تساوى واحد فإنه في هذه الحالة سيتم قراءة مسجل التحكم .
- و البتات D4 و D5 تمثلان كيفية القراءة أو الكتابة من أى واحد من العسدادات الذى تم اختياره بالبتات 6 و 7 . كما نعلم فإن كل عداد مكون من 16 بت ، بينما مسار البيانات الشريحة مكون من 8 بت فقط ، لذلك فإنه لابد من تحديد أى بسيت (8بت) من ال 16 بت سيتم قراءتها أو الكتابة فيها . فإذا كانت البتت 4 تساوى واحد والبت 5 تساوى صفر فإنه في هذه الحالة سيتم التعامل مع البايت الأولى واحد والبت 5 تساوى صفر والبت 5 تساوى واحد فإنه سيتم التعامل مع البايت الثانية في هذه الحالة المناوى صفر والبت 5 تساوى واحد فإنه سيتم التعامل مع البايت الثانية في هذه الحالة بوضع كل من البست 4 و 5 وأخيرا يمكن قراءة البايت الأولى ثم الثانية مباشرة بوضع كل من البست 4 و 5 وأخيرا يمكن قراءة أى عداد في أى لحظة لابد من مسك المحالة ووضعها في مسجل القراءة . بذلك نضمن أنه في أثناء قراءة أى عداد فإنه لابد من مسك محتويات هذا العداد بوضع البتسات 4 و 5 كل منها عداد فإنه لابد من مسك محتويات هذا العداد بوضع البتسات 4 و 5 كل منها تساوى صفر .
- البتات D1 و D2 و D3 يمكن عن طريقها اختيار الحالة mode التى سيعمل عندها العداد الذى تم اختياره . بهذه الثلاث بتات يمكن اختيار حالة من ست حالات يمكن لأى عداد أن يعمل عندها كما في شكل (10-11) .
- البت رقم صفر D0 ويتم عن طريقها جعل العداد الذي يتم اختياره يعد عشرى أو ثنائي . فإذا كانت هذه البت تساوى صفرا فإن العداد المختار سيعد عدا ثنائيا من 0 حتى FFFFH ، أما إذا كانت هذه البت واحد فإن العداد سيعد عشريا من صفر حتى 9999 .

#### PIT حالات تشغيل الشريحة 2-7-16

#### الحالة 0

شكل (16–11) يبين الست حالات التي يمكن أن يعمل فيها أي عداد من العدادات الثلاثة الموجودة في الشريحة 8254 . في الحالة 0 وكما هو مبين في شكل (16–11) فإن الخرج OUTX يكون واحد إلى أن يتم تحميل العداد رقم X بـــالرقم X ويتم تتشيط الخط GATEX حيث عندها ينزل الخسرج OUTX إلى الصفر ، ويظل كذلك إلى أن ينتهى العداد X من عد X من نبضات الساعة حيست عند النبضة X النبضة X الخرج إلى الواحد مرة ثانية ، في هذه الحالة X المن يكون الخط X والمحالة X المناه الخط X المناه الخط X المناه الخط X المناه المناه الواحد مرة ثانية ، في هذه الحالة X المناه الخط X

#### الحالة 1

في هذه الحالة سيعمل العداد كمؤقت أحادى الاستقرار يتم تتشيطه مسن الطرف GATEX حيث بإعطاء نبضة على هذا الخط فإن الخرج سينزل إلى الصفر ويظل كذلك إلى أن يصل العداد إلى القيمة المبرمجة حيث عندها يصعد الخرج الى الواحد . لاحظ الفرق بين هذه الحالة والحالة السابقة والذى يقع فقط في كيفية تتشيط الطرف GATEX . في هذه الحالة إذا تم إعطاء نبضة تتشيط على الطرف GATEX أثناء نشاط الخرج ، فإن الخرج سيبدأ فترة نشاط جديدة كما في الخطوط المنقطة في شكل (16-11) .

#### الحالة 2

هذه الحالة يوضحها شكل (16-11) حيث يكون الخرج عديم الاستقرار . في هذه الحالة يكون الخرج واحد طالما أن العداد لم يصل إلى القيمة المسرمج عليها ، وعندما يصل إلى هذه القيمة فإن الخرج ينزل إلى الصفر لمدة زمن نبضة تزامن واحدة ثم يرجع واحد ، وهكذا يتأرجح الخرج بين الواحد والصفر بتردد وأزمنة تأخير يتم التحكم فيها بالقيمة المخزنة في العداد . لاحظ أن الطرف GATEX في هذه الحالة لابد أن يكون فعالا .

#### الحالة 3

هنا يكون الخرج أيضا عديم الاستقرار حيث يكون عبارة عسن موجة مربعة يتساوى فيها زمن الواحد وزمن الصفر وكل منهما له زمن يساوى نصف الزمن الناتج عن القيمة المبرمجة في العداد إذا كانت هذه القيمة زوجية ، أما إذا كان العداد محمل بقيمة فردية فإن زمن الصفر يكون أقل بمقدار زمن نبضة تزامن واحدة عن زمن الواحد .



#### الحالة 4

بعد مرور عدد من النبضات مساوى القيمة المحملة فى العداد ، فإن خرج العداد سينزل إلى الصفر لمدة زمن نبضة واحدة فقط بعدها يعود الخرج واحد كما كان ويظل كذلك إلى أن يتم برمجة العداد مرة أخرى . يمكن إخماد النبضة الناتجة عن طريق جعل الخط GATEX يساوى صفر .

#### الحالة 5

هذه الحالة تشبه تماما الحالة 4 سوى أن زمن التأخير يبدأ عند إعطاء نبضة على الخط GATEX حيث بعد هذه النبضة بزمن يتحدد بالقيمة المبرمجة في العداد ينزل الخرج للصفر لمدة زمن نبضة تزامن واحدة بعدها يرجع الخرج واحد موة ثانية في انتظار إعطاء نبضة أخرى على الطرف GATEX . لاحظ أن تتسيط زمن التأخير في الحالة 4 يتم برمجيا (فقط يكون الطرف GATEX أسط) بينما في الحالة 5 فإن زمن التأخير يتم تتشيطه بالطرف GATEX أي Hardware .

# 8-16 الاتصالات القابلة للبرمجة Programmable Communication Interface, PCI 8251

الشريحة 8251 مصممة لتقوم بمواجهة نظم الاتصالات التتابعية مع المعالج . كما نعلم فإن عملية نقل البيانات إما أن تكون على التوازى ، أى أن المعلومة ترسل في صورة بايت (8بت) كاملة على 8 خطوط إلى الهدف ، أو ترسل تتابعيا أى بت بعد بت على خط واحد مثل خط التليفون . في العادة تستخدم الطريقة التتابعية عندما تكون المسافة بين المرسل والمستقبل كبيرة .

الشريحة 8251 عبارة عن مرسل Transmitter و مستقبل Receiver للبيانات الغير متزامنة Synchronous أو البيانات المتزامنة Synchronous ، واذاك يرمز لها بالاختصار USART والذي يعنى ما يلى :

Universal Synchronous Asynchronous Receiver Transmitter وتتميز الشريحة بمعدلات إرسال baud rate عالية والتي تتمثل في عدد البتات التي يمكن إرسالها في الثانية الواحد .

البيانات الغير متزامنة هي البيانات التي يتم إرسالها واستقبالها دون الحاجة إلى البيانات الغير متزامنة هي البيانات التي يتم إرسالها واستقبالها دون الحاجة إلى 10 نبضات تزامن Clock . شكل (16-12) يبين إطارين من البيانات كل منهما منهما يحتوى على بت البداية Start bit ، وسبع بتات تمثل البيانات

المرسلة Data bits ، وبت للباريتي Parity bit وأخيرا بــت للنهايــة Stop bit ، وبالحظ هذا عدم وجود نبضات تزامن مع هذه البيانات .



إن مهمة الشريحة 8251 هي إضافة بتات البداية والنهاية والباريتي للبيانات المطلوب إرسالها ، ثم بعد ذلك تقوم بنقل هذه البتات مع البيانات المطلوب إرسالها على التتابع على خط الإرسال أو قناة الإرسال . عند المستقبل توجد شريحة أخرى من نفس النوع تقوم بالمهمة العكسية حيث تفصل البتات الإضافية عن البيانات الأساسية وتحسب الباريتي هل هي سليمة أم لا .

أما البيانات المتزامنة فلا تحتوى بتات إضافية بجانب بتات البيانات مثل بتسات البداية والنهاية ولكن جميع البتات تمثل بيانات . كل بت من بتات البيانات لابدية والنهاية ولكن جميع البتات تمثل بيانات . كل بت من بتات البيانات لابدية أن تكوم متزامنة مع نبضة من نبضات التزامن كما في شكل (16-12ب) ، أمسا بداية إطار البيانات فتحدد بحرف تزامن . لن نخوض في تفاصيل هذه الشريحة وطريقة برمجتها لقلة المتعاملين معها كشريحة منفصلة ولكن فسى العادة يتم التعامل معها كأحد مكونات نظام اتصالات متكامل .

### 9-16 الاتصال المباشر مع الذاكرة Direct Memory Access, DMA 8237A

لقد رأينا في طرق التعامل مع الأجهزة الخارجية كيف أنه لكي نخزن معلوم...ة معينة من جهاز خارجي في الذاكرة ، فإننا لابد أن نقــرأ المعلومــة أو لا عـن طريق المعالج ثم ننقلها بعد ذلك من المعالج إلى الذاكرة في العنوان المحدد . أى أن المعالج لابد وأن يكون وسيط في عملية نقل المعلومات من وإلى الذاكرة. مع تقدم الحاسبات وزيادة كمية البيانات التي يتم تداولها بين الأجهزة الخارجيــة والذاكرة الفعالة أو الأساسية ظهرت هناك فكرة تحريسر المعالج من عملية الوساطة هذه بحيث تكون عملية نقل البيانات من الأجهزة المحيطة للذاكرة مباشرة ودون دخول المعالج كوسيط مما سيسرع من عملية نقل البيانات بدرجة كبيرة ، وهذا ما يطلق عليه الاتصال المباشر بالذاكرة . شكل (16-13) يبين رسما توضيحيا لهذه العملية . نلاحظ في هذا الشكل وجود جهاز خارجي يتحكم في هذه العملية وهو عبارة عن الشريحة 8237A والتي تمر من خلالها البيانات يتحدد دورها في تحديد العناوين والغرض من التعامل مع الذاكرة هل هو القراءة.أم الكتابة . عندما يريد أي واحد من الأجهزة الخارجية مثل الاسطوانة الصلبة أن يتصل مباشرة بالذاكرة ، فإنه يطلب ذلك من المعالج عن طريق تتشيط الخط HOLD الداخل للمعالج بجعله يساوى واحمد . عند ذاسك وبعمد الانتهاء من تتفيذ الأمر الحالى الذى ينفذه المعالج ، يقوم المعالج بالانفصال عن المسارات الثلاثة (البيانات والعناوين والتحكم) بجعلها جميعا في حالة المقاومـــة العالية أو الحالة المنطقية الثالثة . بعد ذلك يخبر المعالج الجهاز الخارجي بأنـــه قد انفصل عن المسارات عن طريق تتشيط الخط HLDA بجعله يساوى واحد . عندما يشعر الجهاز الخارجي بذلك يفهم أن جميع المسارات أصبحت تحت سيطرته فيبدأ في إرسال أو استقبال البيانات بمساعدة الشريحة 8237A . يظـل المعالج منفصد عن المسارات إلى أن يقوم الجهاز الخارجي بإخماد الخط HOLD إلى الصفر مرة أخرى حيث عندها يعود المعالج إلى السيطرة علسي المسارات مرة أخرى .

باستخدام الشريحة 8237A يمكن الاتصال المباشر بالذاكرة من خلال 4 قنوات اتصال . سنكتفى بهذا القدر من المعلومات عن هذه الشريحة لندرة استخدامها أيضا على المستوى الشخصى واستخدامها عادة في الأنظمة المتكاملة مثل أنظمة الحاسب .

# 10-16 المواجهة مع المعالجات الحسابية المساعدة Arithmetic Coprocessor 80X87

عائلة المعالجات الحسابية المساعدة Arithmetic coprocessors هي عبارة عسن معالجات تقوم بتنفيذ العمليات الحسابية والمقارنات بسرعة تقوق سرعة المعالج العادى حوالي 100 مرة وبالذات الدوال الحسابية مئل دوال حساب المثلثات ودوال الأسس وغيرها . بالإضافة إلى ذلك فإن هذه المعالجات تسهل بدرجة كبيرة التعامل مع البيانات المختلفة مثل الأرقام الصحيحة والحقيقية ذات الدقة المختلفة .

ابتداء من المعالج 8086 حتى المعالج 80386 سنجد أن كل منها لـــه المساعد الحسابي الخاص به والذي يعمل معه ، فمثلا المعالج 8086 مساعده الحسابي هو الشريحة 8087 ، والمعالج 80186 مساعده الحسابي هي المعالج 80187 وهكذا . ابتداء من المعالج 80486 بدأت شركة intell تضع كل معالج ومساعده الحسلبي في نفس الشريحة التكاملية بحيث أصبحت الأنظمة الحسلبية لا تحتاج إلـي المواجهة الخارجية مع المساعد الحسابي .

إننا لن نخوض أيضا فى تفاصيل مواجهة المعالجات المساعدة مع المعالج الأساسى لعدة أسباب منها ندرة استخدامها على المستوى الفردى ، وثانيا أن هذه المعالجات دخلت الآن ضمن مكونات المعالج العادى على نفس الشريحة بحيث أصبحت لا تتتج بصورة منفصلة .



#### 11-16 تمسارين

- 1. ما هو نوع الإشارة الموجودة على مسارى البيانات/العناوين حينما يكون الخط ALE فعالا ؟
  - 2. ما هو الغرض من خطوط الحالة 33 و S4 ؟
- $\overline{\mathrm{RD}}$  . ما هى الحالة التى يكون فيها المعالج 8086/8088 حينما يكون الطرف  $\overline{\mathrm{RD}}$  يساوى صفرا ؟
  - 4. اشرح الأطراف التالية للمعالج 8086/8088:

- HOLD
- HLDA
- DT/R
- LOCK
- TEST
- READY

- 5. ما هو الغرض من الطرف BHE ؟
- 6. لماذا نحتاج في العادة لعملية فصل لمسارات أي معالج ؟
- 7. كيف نحد اتجاه الإشارة على مسار البيانات عند استخدام الشريحة 74245
   في عملية عزل المسارات ؟
  - 8. ما هو زمن الاتصال بالذاكرة ؟
  - 9. ما هو الغرض من الطرف DEN
  - 10.ما هو الغرض من الطرف  $\overline{\text{CS}}$  والطرف  $\overline{\text{OE}}$  في أي شريحة ذاكرة ؟
    - 11. ارسم المشفر اللازم لعنونة المدى العنواني DF800H-DFFFFH ؟
- 12. ارسم المشفر اللازم لعنونة المدى العنواني 10000H-1FFFFH باستخدام 8 شرائح EPROM سعة كل منه 8 كيلوبايت .
- 13. أضّف 8 شرائح RAM أخرى لنظام الذاكرة الموجود في المسألة السابقة ، الشرائح سعة كل منها 2 كيلوبايت . ابدأ المدى العنواني لسهذه الشرائح عند العنوان 20000H .
  - 14. ما هو الغرض من الطرف AO غير كونه خط عنونة ؟
- 15. اشرح كيف نحصيل على الخطوط MEMR و MEMW في المعالج 15. 8086/8088 .

# الفصل السابح عشر

ثم ماذا؟

What else?

### 1-17 مـقـدمــة

ثم ماذا بعد أن درسنا بالتفصيل المعالجين 8085 و 280 كعينات من المعالجات ذات 8 بت والتي تتميز ببساطتها وسهولة برمجتها وسهولة مواجهتها مع الدواتر الخارجية ، ولذلك فإنها غالبا تكون هي المرشحة للاستخدام في بناء دوائر التحكم التي نراها كثيرا في التطبيقات الصناعية والكثير من الأجهزة الحديثة . ثم بعد ذلك درسنا بالتفصيل أيضا المعالج 8086/8088 كاحد المعالجات 16 بت والذي ، كما سنرى ، سيكون هو الأساس لكل المعالجات التالية التي سنراها في هذا الفصل . ولذلك فإننا لن نخوض في تفاصيل هذه المعالجات ولكننا سنكتفى بدراسة الإضافات والفروق التي تمت عليها . سنحاول بقدر الإمكان تغطية جميع المعالجات ابتداء من المعالج 80186 وانتهاء بالمعالج بنتيم برو Pentium Pro أحدث المعالجات في الساحة الآن .

### 2-17 المعالج 80186

شكل (1-1) يبين رسما صندوقيا لمحتويات المعالج 80186. هذا المعالج يشبه الى حد كبير سابقه المعالج 8086 من حيث مسار البيانات الذي يتكون من 10 بت ومسار العناوين الذي يتكون من 20 بت . الجديد هنا هدو أن الكثير مسن الشرائح الضرورية التي كان يستعملها المعالج 8086 وكانت توصل معسه من الخارج ، تم إدخالها جميعها داخل شريحة المعالج نفسه ونلك لتبسيط دوائس المواجهة مع المعالج 80188 . المعالج 80188 له رفيق آخر وهو المعالج 80188 الذي يشبهه تماما فيما عدا أن مسار البيانات الخارجي يتكون من 8 بت بدلا من 16 بت . ماز ال كل من المعالجين أيضا يتكون من وحدتين أساسيتين وهما وحدة التنفيذ Bus Interface Unit, EU يوضح البلوكات الأساسية التالية للمعالج 80186 :

### 1. وحدة نبضات الساعة Clock Generator

هذا المولد يحل محل الشريحة 8284A التي قدمناها في فصل سابق والتي كانت توصل من خارج المعالج لتوفير نبضات الساعة وتوفير عمليات النزامن لكتسير من إشارات التحكم مثل الطرف Ready .



هذا البلوك يخرج منه الطرفان X1 و X2 اللذان يوصل عليهما بللـورة Crystal ذات تردد يساوى ضعف التردد المطلوب للمعالج ، فإذا كان المعالج سيعمل عند تردد 8 ميجاهيرتز مثلا فإن البلورة يجب أن يكـون ترددها 16 ميجاهيرتز . يخرج أيضا من هذا البلوك الطرف CLKOUT الذي يحمـل نبضـات الساعة الناتجة من داخل المعالج إلى خارجه حتى يمكن استعمالها بأي دائرة خارجية .

### 2. وحدة منظم المقاطعة القابل للبرمجة

Programmable Interrupt Controller, PIC

يحتوى المعالج 80186 على الشريحة 8259A التى تقوم بتنظيم عمليات المقاطعة حسب أولويات وصولها .هناك خمس مداخل لهذا البلوك وهى خطوط المقاطعة . INT3, INT2, INT1, INT0 وخط المقاطعة الغير قابل للحجب Nonmaskable .

#### 3. وحدة المؤقتات Timers

يحتوى هذا الجزء على ثلاث مؤقتات كل منها 16 بت وكلها قابلة للبرمجة مثل الشريحة 8254A والتى تتاولناها فيما سبق بالتفصيل . كل هذه المؤقتات يمكنها أن تعمل إما على نبضات الساعة الداخلية الموجودة في المعالج ، أو مع نبضات خارجية بأى تردد مطلوب .

### 4. وحدة الاتصال المباشر بالذاكرة

**Direct Memory Access, DMA** 

يحتوى المعالج 80186 على وحدة اتصال مباشر بالذاكرة DMA ذات قناتى اتصال قابلة للبرمجة مشابهة تماما للشريحة 8237A .

## 5. وحدة اختيار الشرائح القابلة للبرمجة

Programmable Chip Select Unit, PCS

هذه الوحدة عبارة عن مشفر قابل البرمجة يوفر 6 خطر وط الاختيار عناوين القاعدة base addresses أو عناوين البداية المقاطع ذاكرة مختلفة ، كما توفر 7 خطوط الاختيار عناوين بوابات إدخال أو إخراج . فكر في مدى ما يوفره مثل ذلك من التوصيلات الخارجية في حالة تشفير هذه العناوين خارجيا .

يصدر المعالج 80186 في شريحة مكونة من 68 طرفا في شكل مربع مختلف عن كل الشرائح السابقة ذات 40 طرفا . شكل (17-2) يبين رسما طرفيا لهذا المعالج وفيما يلى سنعرض فكرة مبسطة عن وظيفة كل طرف من هذه الأطراف:

### 1-2-17 أطراف المعالج 80186

- الطرف Vcc وهو طرف القدرة لهذا المعالج ويساوى 5 فولت وهو الطرف رقم 9 في الشريحة .
  - الطرف Vss ويمثل الأرضى الخاص بالشريحة .

- الطرفان X1 و X2 وكما ذكرنا يوصلان على بللورة من الخارج المصول على نبضات التزامن اللازمة . لاحظ أن تردد النبضات داخل المعالج يكون نصف تردد البلورة .
- الطرف CLKOUT تخرج عليه نبضات التزامن التي تم الحصول عليها حتى يمكن استخدامها بواسطة الأجهزة الخارجية .



- الطرف RES وهو طرف إعادة الوضع للمعالج Reset ويجب أن يظل هذا الطرف صفرا لمدة 50 ميللثانية حتى يتم إعادة الوضع . عند تتشيط هذا الطرف يذهب المعالج للعنوان FFFFOH لتنفيذ ما هناك من أوامر .
- الطرفان TMRIN0 و TMRIN1 يتم إدخال نبضات الساعة الخاصة بالمؤقتين 0 و 1 على هذين الطرفين .

- الطرف TEST ، يستخدم هذا الطرف بواسطة الأمر WAIT حيث أنه عندما يكون هذا الطرف فعالا (0) فإنه لن يكون هناك انتظار ، ولكى يتم الانتظار لابد أن يكون هذا الطرف واحد .
- الطرفان TMROUT0 و TMROUT1 وهما طرفا خرج تخرج عليهما إشارة خرج المؤقتين والتي تكون إما في صورة موجة مربعة أو نبضة واحدة .
- الطرفان DRQ0 و DRQ1 و هما طرفا دخل يتسم عليسهما طلب الاتصسال المباشر مع الذاكرة DMA من خلال القناتين 0 أو 1 وهما فعالان عندما يكسون كل منهما 1 .
- الطرف NMI وهو طرف دخل ، تدخل عليه إشارة طلب المقاطعة الغير قابلة للحجب nonmaskable ، وهذا الطرف ينشط مع الحافة الصاعدة للإشارة .
- الأطراف INT0 و INT1 و INT2/INTA0 و INT3/INTA1 ، كلها أطراف دخل تدخل عليها إشارة طلب المقاطعة القابلة للحجب والتي أرقامها 0 و 1 و 2 و 3 و كلها فعالة عندما تكون 1 . هذه الخطوط يمكن برمجتها لتكون 4 خطروط طلب مقاطعة ، أو خطين لطلب المقاطعة وخطين للاعتراف acknowledge بهذه المقاطعة .
- الخطوط A16/S3 و A17/S4 و A18/S5 و A19/S6 ، عبارة عن 4 أطراف تستخدم فكرة المزج الزمنى بين إشارة العناوين A16 إلى A19 وخطوط الحالمة S3 إلى S6 . خط الحالة S6 يبين إذا كان المعالج في حالة اتصال مباشر مسع الذاكرة حيث عندها يكون هذا الخط 1 ، ويكون صفرا في حالة التشغيل العددى للمعالج . باقى خطوط الحالة تكون أصفارا .
- الخطوط AD0 إلى AD15 ، عبارة عن 16 خط تخرج عليها إشارة العناوين والبيانات في مزج زمني مثل المعالج 8086 .
- الطرف 57/BHE طرف خرج يبين إذا كانت الإشارة الموجودة على النصف العلوى من مسار البيانات تمثل بيانات محققة ، هذا الخط ممسزوج زمنيا مع الإشارة 57 .
- الطرف ALE/QSO وهو طرف خرج عبارة عن مزج زمني بين إشارة تنشيط ماسك العناوين Address Latch Enable, ALE والإشارة QSO والتي تمثل حالة طابور queue الأوامر في وحدة مواجهة المسارات.
- الطرف  $\overline{WR}/QS1$  ، خط خرج يبين إذا كان المعالج يكتب بيانات إلى الذاكرة أو وحدة إخراج . هذا الطرف ممزوج زمنيا مع الإشارة QS1 التى تمثل الإشارة الثانية لحالة طابور الأوامر .
- الخط RD/QSMD خط خرج يبين إذا كان المعالج يقرأ من الذاكرة أو مسن وحدة إدخال . هذا الخط ممزوج زمنيا مع الخط QSMD أو خسط بيان حالسة الطابور Queue Status Mode .

- الطرف Asynchronous Ready, ARDY طرف دخل المعالج يخبره إذا كانت الذاكرة أو وحدة الإدخال أو وحدة الإخراج جاهزة Ready . عندما يكون هذا الخط صفر يدخل المعالج في حالة انتظار .
- الطرف Synchronous ready, SRDY هذا الطرف مثله مثل الطوف ARDY فيما عدا أنه لابد و أن يكون متزامن مع نبضات الساعة الخاصة بالنظام. إذا كان هذا الخط صفر يدخل المعالج في حالة انتظار.
- الطرف LOCK خط خرج ببين إذا كان الأمر الذي يتم تنفيذه أمر محظور على المعالج المساعد أم لا ، حيث أنه يمكن إضافة بايت قبل أي أمر تمنع المعالج المساعد من الحصول على مسارات النظام ، وفي هذه الحالة يكون الطرف LOCK فعالا ويساوى صفرا .
- الخطوط  $\overline{S0}$ ,  $\overline{S1}$ ,  $\overline{S0}$  أطراف خرج تمثل حالة المعالج أثناء أي عملية نقل البيانات .
- الطرف HOLD طرف دخل يطلب من المعالج الانفصال عن المسارات لكي تتم عملية اتصال مباشر DMA مع أحد الأجهزة الخارجية .
- الطرف HOLDA طرف خرج يمثل إشارة اعــتراف مـن المعـالج بقبـول الانفصال عن المسارات .
- الطرف Upper memory Chip Select, UCS طرف خرج يستخدم كخط الختيار لعناوين الذاكرة في الجزء العلوي من خريطة الذاكرة . يمكن برمجة هذا الطرف لاختيار من 1 كيلو بايت حتى 256 كيلو بايت تتهي بالعنوان FFFFF .
- الطرف Lower memory Chip Select, LCS طرف خرج يستخدم كخط اختيار لعناوين ذاكرة في الجزء الأدنى من خريطة الذاكرة . أيضا يمكن برمجة هذا الخط لاختيار من 1 كيلو بايت حتى 256 كيلو بايت تبدأ بالعنوان 00000H.
- الأطراف Mid Memory Chip Select MCSO-MCS3 أربع أطراف خــرج تستخدم كخطوط اختيار لعناوين الذاكرة في أي مكان فــي الخريطـة. يمكـن برمجة أي طرف الاختيار من 8 كيلو بايت وحتى 512 كيلو بايت تبــدأ عنـد أي عنوان في الذاكرة.
- الأطراف PCSO-PCS4 خمس خطوط خرج تستخدم لعنونة أجهزة الإخراج
   والإدخال .
  - الطرفان PCS5/A1, PCS6/A2 خطوط خرج تستخدم إما لعنونة أجهزة الإخراج والإدخال مثل PCS0-PCS4 ، أو كخطوط عنونة A0, A1 .
  - الطرف DT/R خط خرج يبين اتجاه البيانات على مسار البيانات إذا كانت خارجة أم داخلة المعالج .
  - الطرف DEN يستخدم لتنشيط فواصل مسار البيانات الخارجية حيث يكون
     هذا الخط فعال (0) في حالة وجود بيانات على مسار البيانات .

#### 2-2-17 برمجة المعالج 80186

جميع أو امر الشريحة 8086 قابلة التتفيذ دون أي مشاكل مسع المعالج 80186. يحتوي المعالج 80186 بعض الأو امر الإضافية التي لم تكن موجودة أصلا مسع المعالج 8086 من هذه الأوامر ما يلي:

• ليس هناك أمر في المعالج 8086 يضرب قيمة فورية أو ثابت في محتويات أي مسجل ، فمثلا الأمر 3086 ولكن الله MUL BX, 2300H غير معرف مع المعالج 8086 ولكن مع المعالج 80186 يمكن ضرب أي قيمة فورياة في محتويات أي مسجل باستخدام الأمر

#### IMUL BX, data 16

حيث سيضرب الثابت data16 في محتويات المسجل BX ويضع النتيجية في المسجل BX .

- الأمر SHL BX, 4 هذا الأمر يقوم بإزاحة محتويات المسجل BX اليسار بمقدار 4 أماكن أو 4 بتات . في المعالج 8086 كان هناك إمكانيسة للدوران أو الإزاحة بمقدار بت واحدة فقط .
- هناك بعض الأوامر الإضافية على عمليات الإضافة PUSH والسحب POP من المكدسة.

بالطبع لابد وأن يكون هناك أوامر إضافية للتعامل مع الشرائح الإضافية والتي أدخلت داخل شريحة المعالج مثل المؤقتات والاتصال المباشر مع الذاكرة والمقاطعة.

سنكتفي بذكر هذه الفروق في صورة عامة دون الدخول في تفاصيل وذلك لندرة البرمجة أو الحاجة لهذه الأوامر الإضافية .

# 3-17 المصعالج 30286

المعالج 80186 لم يستمر كثيرا في السوق ولم يتعدى عمر خدمته في أنظمة الحاسبات سوى عام أو عامين على الأكثر حتى ظهر المعالج 80286 الذي كان بداية نقلة من الحاسبات XT إلي الحاسبات AT . المعالج 80286 عبارة أيضا عن امتداد للمعالج 8086 ويستطيع التعامل مع ذاكرة مقدار ها 16 ميجا بايت نتيجة زيادة خطوط العناوين إلي 24 خطا بدلا من 20 خطا في حالة المعالج 8086 . هذا بالإضافة إلي وحدة جديدة وهي ما يسمى بوحدة إدارة الذاكرة الذاكرة التخيلية تصل إلى 1 جيجا بايت . هذا بالإضافة إلى أن المعالج 80286

يمكنه التعامل مع أكثر من مستخدم ولذلك يطلق عليه بأنه متعدد المستخدمين Multi-user . Multi-user

## 1-3-17 التركيب الهيكلي للمعالج 80286

شكل (17-3) يبين رسما صندوقيا للمعالج 80286 حيث نلاحظ من هذا الشكل أن المعالج 80286 لا يحتوي شرائح المواجهة التي كانت موجودة في المعالج 80186 ولكن بدلا من ذلك فإنه يحتوي على وحدة إدارة الذاكرة الجديدة MMU و التي يطلق عليها وحدة العنونة Address Unit في هذا الشكل.

يمكن للمعالج 80286 أن يعمل في واحدة من حالتين ، الحالة الأولى تسمى الحالة الحقيقية real mode وفيها يكون المعالج 80286 مشابها تماما للمعالج 8086 حيث يكون مسار العناوين في هذه الحالة 20 خطا فقط مما يسمح بعنونة 1 ميجا بايت ، أما باقي خطوط العناوين A20-A23 فتكون أصفارا في هذه الحالة ، وفي هذه الحالة فإن جميع برمجيات software الشريحة 8086 سوف تعمل معلم المعالج 80286 بدون أي تعديل أو أي مشكلة .

بالإضافة لما تقدم ، تحتوى الشريحة 80286 على بعض المسجلات الإضافية الغير موجودة في الشريحة 8086 المستخدمة في وحدة إدارة الذاكرة . بالطبع فإنه نتيجة إضافة وحدة الذاكرة فلابد أن يكون هناك مجموعة من الأوامر الإضافية التي تستخدم للتحكم في هذه الوحدة ، وهذه المجموعة هي الاختلف الوحيد في مجموعة الأوامر بين المعالج 80286 والمعالج 8086.

يستخدم المعالج 80286 فكرة الذاكرة التخيلية virtual memory بحيية يمكن تخصيص جزء من الذاكرة لكل مستخدم user أو كل هدف task . يجب أن نتذكر جيدا أنه عندما يقوم المعالج بتنفيذ عدة برامج لأكثر من مستخدم أو أكثر من مستخدم أو أكثر من هدف على التوازى فإنه في الحقيقة ينفذ جزء من البرنامج الأول الذي يكون ذو أولوية عالية ، وإذا انخفضت أولوية هذا الهدف نتيجة تتفيذ جزء منه ، فإلم المعالج يتركه وينفذ في الهدف الثاني أو الثالث ثم يرجع للهدف الأول وهكذا ، أي أن عملية التنفيذ تكون موزعة على الأهداف على النتابع ونتيجة السرعة في تنفيذ هذه البرامج يشعر كل مستخدم كما لو كانت كل هذه المبرامج تنفيذ على التوازى .



من المشاكل الأساسية الموجودة في المعالج 80286 أنه عندما يدخل في الحالسة المحمية التخيلية فإنه لا يستطيع الخروج منها والرجوع إلى الحالة الحقيقية real المحمية الإ إذا تمت إعادة وضع reset المعالج ، وهذه بالطبع مشكلة كبيرة لأنسها تأخذ وقتا كبيرا وتفقدك كل محتويات الذاكرة . هذه المشكلة تم التغلب عليها فسى المعالج 80386 .

### 4-17 المعالج 80386

كانت أول متطلبات هذا المعالج هي تطوير المعالج 80286 بحيث يمكن الرجوع من الحالة المحمية إلى الحالة الحقيقية بسهولة ، وقد كان ذلك حيث يمكن في المعالج 80386 الانتقال من حالة لأخرى باستخدام أمر معين بدلا من إعادة وضع المعالج ويعتبر هذا إنجازا كبيرا .

الجديد أيضًا في المعالج 80386 أن مسار البيانات له مكون من 32 بت ، أي أنه يستطيع نقل 4 بايت كاملة من أو إلى الذاكرة أو أي جهاز خارجي في رحلة واحدة فقط . كذلك فإن مسار العناوين لهذا المعالج مكون من 32 بت أيضا مما يتيح له التعامل مع ذاكرة مقدارها 4 جيجابايت . أما إذا دخل المعالج في الحالة المحمية protected mode فإنه في هذه الحالة يتعامل مصع 64 تريليون بايت =1024 جيجابايت) من الذاكرة التخيلية وذلك باستخدام وحدة إدارة الذاكرة الذاكرة التخيلية وذلك باستخدام وحدة

### 1-4-17 التركيب الهيكلي Architecture للمعالج 80386

شكل (4-17) يبين الشكل الخارجي لشريحة هذا المعالج وطريقته الجديدة في ترتيب أطرافه ، حيث يخرج من هذه الشريحة 132 طرفا مرتبة في صورة شبكة Grid تعرف كل نقطة فيها برقم الصف متقاطعا مع رمز العمود الذي تقع فيه ، فقول مثلا الطرف 13j هو الطرف Vss و هكذا .

المعالج 386 (اختصار 80386) نزل في إصدارين أو صورتيــن ، الإصدار الأول هو المعالج 386DX وهو الصورة الكاملة لهذا المعالج والتي نحن بصدد دراستها هنا . الإصدار الثاني هو المعالج 386SX الذي يختلف عن الإصدار DX في أن مسار البيانات له يتكون من 16 بت بدلا من 32 وذلك حتى يتوافــق خارجيا مع المعالج 80286 وهذا هو الاختلاف الوحيد بينهما .

#### 2-4-17 تنظيم الذاكرة للمعالج 80386

عندما كان مسار البيانات 8 بت كما في المعالجات 8085 أو 280 كانت الذاكرة تنظم في صورة بنك bank واحد ، عرض هذا البنك هو 8 بت (نفسس عرض مسار البيانات) . عندما تطور مسار البيانات إلى 16 بت أصبحت الذاكرة تنظم في صورة بنكين كل منهما 8 بت بحيث يكون البنك الأول للبايتات الزوجية والثاني للبايتات الفردية ، وكان الخط AO يستخدم لتنشيط البنك الزوجي أو النصف الأدنى في حالة التعامل مع هذا البنك فقط ، والخط BHE يستخدم لتنشيط البنك الفردى أو النصف العلوى في حالة التعامل معه فقط ، أما في حالة التعامل

على مستوى 16 بت فإن كل من البنكين يتم تنشيطهما في نفس الوقت من الخطين A0 و  $\overline{BHE}$  حتى يمكن إرسال 16 بت (كلمة word) مرة واحدة ، ولقد رأينا ذلك في أثناء در استنا للمعالج 8086 . شكل (5-17) يبين طريقة تنظيم الذاكرة في المعالجين 8085 و 8086 .

|     | P   | N   | M        | L    | K   | J   | Н       | G     | F      | E    | D    | C         | В      | A     |          |
|-----|-----|-----|----------|------|-----|-----|---------|-------|--------|------|------|-----------|--------|-------|----------|
| Ī   | 0   | 0   | 0        | 0    | 0   | 0   | 0       | 0     | 0      | 0    | 0    | 0         | 0      | 0     |          |
| 1   | A30 | A27 | A26      | A23  | A21 | A20 | Al7     | A16   | A15    | A14  | A11  | A8        | Vss    | Voc   | 1        |
|     | 0   | O   | О        | 0    | 0   | 0   | Q       | 0     | 0      | 0    | 0    | O         | O      | 0     |          |
| 2   | Vcc | A31 | A29      | A24  | A22 | Vas | A18     | Vcc   | Vss    | A13  | A10  | A7        | A5     | Vss   | 2        |
| - ( | 0   | 0   | 0        | 0    | 0   | 0   | O       | O     | O      | O    | O    | O         | O      | O     |          |
| 3   | D30 | Vss | Vcc      | A26  | A25 | Vss | A19     | Vcc   | Vss    | A12  | A9   | <b>A6</b> | A4     | A3    | 3        |
|     | 0   | 0   | O        |      |     |     |         |       |        |      |      | O         | 0      | 0     |          |
| 4   | D29 | Vec | $v_{ss}$ |      |     |     |         |       |        |      |      | A2        | NC     | NC    | 4        |
|     | O   | O   | O        |      |     |     |         |       |        |      |      | 0         | O      | 0     |          |
| 5   |     | D27 |          |      |     |     |         |       |        |      |      | Vcc       | Vss    | Vcc   | 5        |
|     | 0   | 0   | O        |      |     |     |         |       |        |      |      | O         | 0      | 0     |          |
| 6   | Vss |     | D28      |      |     |     |         |       |        |      |      | NC        | NC     | Vss   | 6        |
|     | O   | O   | 0        |      |     |     |         |       |        |      |      | О         | 0      | 0     |          |
| 7   | D24 |     | Vcc      |      |     |     |         |       |        |      |      |           |        | Vcc   | 7        |
|     | 0   | 0.  | _        |      |     |     |         |       |        |      |      | O         | O      | O     |          |
| 8   |     | D23 | Vss      |      |     |     |         |       |        |      | PERI | _         | _      | RROF  | 8        |
|     | 0   | O   | 0        |      |     |     |         |       |        |      |      | O         | 0      | 0     | ١.       |
| 9   | _   | D21 | D20      | •    |     |     |         |       |        |      | RI   |           |        | Y Vss | 9        |
|     | O   | O   | 0        |      |     |     |         |       |        |      | _    | 0         | 0      | 0     | ١.,      |
| 10  | _ : | D17 |          |      |     |     |         |       |        |      | Ŋ    |           |        | Vcc   | 10       |
|     | 0   | O   | 0        |      |     |     |         |       |        |      |      | 0         | 0      | 0     | ١.,      |
| 11  |     | _   | D15      | _    | _   | _   | _       | _     | _      | _    | _    |           | Vss    |       | 11       |
|     | 0   | O   | 0        | O    | O   | 0   | 0       | 0     | O      | O    | 0    | 0         | 0      | O     | ١,,      |
| 12  |     | D12 |          | Vcc  | D7  | Vss |         |       | CLK    | -    |      | _         | _      | M/IO  | $1^{12}$ |
| 10  | 0   | O   | 0        | 0    | 0   | 0   | 0       | 0     | 0      | 0    | 0    | 0         | O      | O     | ١,,      |
| 13  |     | DII |          | D8   | D5  | Vss |         |       | NC     | NC   |      | _         | _      | BE3   | 13       |
|     | 0   | 0   | 0        | 0    | 0   | O   | 0       | 0     | .0     | 0    | 0    | 0         | O      | O     | ١.,      |
| 14  | Vss | D9  | HLDA     | 7 D6 | D4  | D3  | D2      | VCC   | · VSS  | ADS  | HOL  | ) BS      | 16 Vss | VCC   | 14       |
|     | P   | N   | M        | L    | K   | J   | H       | G     | F      | E    | D    | C         | В      | A     |          |
|     |     |     | 802¢     | 96 - | . N | 11  | الما، ة | سم اا | . 31.4 | 11-1 | 7) . | 15.8      | :      |       |          |

مسار البیانات فی المعالج i386 مکون من 32 بت ، أی أنه سیتعامل مع ذاکــرة مقدارها 4 جیجابایت ستقسم کما فی شکل (6-17) فی صورة 4 بنکات کل بنــك سیکون له خط تتشیط منفصل و هی الخطوط  $\overline{BE0}$  إلی  $\overline{BE3}$  بحیث أنــه عندمــا یتعامل علی مستوی بایت واحدة فإنه یتم تتشیط البنك المطلوب بخــط التشـیط المناسب له ، وعندما یتعامل علی مستوی 16 بت فإنه ینشط إما الخطین  $\overline{BE0}$  و

 $\overline{\mathrm{BE1}}$  في نفس الوقت في حالة التعامل مع الكلمة الأولى ، أو الخطين  $\overline{\mathrm{BE2}}$  و  $\overline{\mathrm{BE3}}$  في نفس الوقت في حالة التعامل مع الكلمة الثانية (العليا) . أما في حالية التعامل على مستوى 32 بث (4 بايت) ففي هذه الحالة تنشط كل الخطوط  $\overline{\mathrm{BE0}}$  إلى  $\overline{\mathrm{BE3}}$  في نفس الوقت .





عند إعادة وضع reset المعالج i386 فإنه يذهب إلى العنوان FFFFFFFOH حيث يبدأ التنفيذ من هناك .

## 3-4-17 نظام الإدخال والإخراج في المعالج 80386

المعالج 386 مثل ما سبقه من المعالجات يستطيع التعامل مع عدد مسن بوابسات الإدخال أو الإخراج يصل إلى 64 كيلسو ، أى أن المسدى العنوانسى للإدخسال والإخراج هو من صفر إلى FFFFH . الجديد هنا سيكون فى طريقة تنظيم هذه العناوين فى صورة بنكات نتيجة كون مسار البيانات أصبح 32 بت . نتيجة لذلك سيقسم هذا المدى العنواني إلى 4 بنكات كما فى شكل (7-7) حيث ستستخدم خطوط النتشيط  $\overline{BE0}$  إلى  $\overline{BE0}$  لتنشيط البنك المناسب للتعامل معه سسواء كسان التعامل فى صورة 8 أو 16 أو 32 بت .

### 4-4-17 أطراف المعالج 80386

1. الأطراف A0 إلى A31 تمثل مسار العناوين ، وتستخدم لعنونة 4 جيجابايت كما ذكرنا ، الجديد هنا أن خطوط العناوين والبيانات ليست ممزوجة زمنيا معنها كما كما كان الحال في المعالجات السابقة .



- 2. الأطراف D0 إلى D31 تمثل مسار البيانات.
- 3. الأطراف  $\overline{BE0}$  إلى  $\overline{BE3}$  هي خطوط تنشيط البنوك المختلفة في الذاكرة والإدخال والإخراج على حسب نظام التعامل 8 أو 16 أو 32 بت .
- 4. الطرف M/IO طرف خرج يبين إذا كان العنوان الموجود على مسار العناوين يمثل ذاكرة (حيث يكون هذا الطرف واحد) أم عنوان لبوابة إدخال أو إخراج (حيث يكون هذا الطرف صفر).

- 5. الطرف  $\overline{W/R}$  طرف خرج يبين إذا كان التعامل الحسالي سيكون بغرض القراءة حيث يكون هذا الطرف واحد. القراءة حيث يكون هذا الطرف واحد. لاحظ أنه في كل المعالجات السابقة كان هناك خطان أحدهما للقراءة  $\overline{RD}$  والآخر للكتابة  $\overline{WR}$ .
- 6. الطرف  $\overline{ADS}$  طرف خرج يحمل إشارة تبين إذا كانت الإشارة الموجودة على مسار العناوين تمثل عنوان محقق للذاكرة أو ليوابة إدخال أو إخراج ADdress مسار العناوين تمثل عنوان محقق للذاكرة أو ليوابة إدخال أو إخراج Status . هذا الخط يستخدم في العادة مع الخط  $\overline{WR}$  و  $\overline{MEMW}$  .
- 7. الطرف RESET ، طرف دخل عندما يكون واحد يسبب إعادة وضعع reset للمعالج حيث يذهب المعالج للعنوان FFFFFFOH ويبدأ التنفيذ من هناك .
- 8. الطرف CLK2 ، طرف دخل يحمل نبضات الساعة Clock للمعالج . تـــردد هذه النبضات يجب أن يكون ضعف التردد المطلوب للمعالج لأنه يتم قسمة هـــذا التردد على 2 قبل استخدامه داخل المعالج .
- 9. الطرف READY ، طرف دخل يستخدم لإدخال دورات انتظار على المعالج حينما يكون نشط (0) .
- 10. الطرف LOCK يستخدم لمنع أى جهاز خارجى أو معالج مساعد مثل المساعد الحسابي 1387 من الحصول على المسارات .
- 11. الطرف DTC ، طرف خرج يعنى Data/Control ويبين إذا كانت الإشارة الموجودة على مسار البيانات تمثل بيانات أم إشارة تحكم يخرجها المعالج عند تنفيذ الأمر HALT أو أنه يرسل إشارة اعتراف بالمقاطعة Acknowledge .
- 12. الطرف BS16 ، طرف دخل يستخدم لتغيير نظام العمل على مسار البيانات بجعله 16 بت بدلا من 32 بت . حينما يكون هذا الخط صفرا يتعامل المعالج على أساس أن مسار البيانات 16 بت ، وحينما يكون واحد يعتبر مسار البيانات 36 بت .
- 13. الطرف NA ، ويعنى Next Address أو العنوان التالى ، وهو طرف دخل يستخدم لجعل المعالج يخرج العنوان التالى في أثناء تتفيذ الأمر الحالى حيث تستخدم هذه الطريقة لإسراع عملية الاتصال بالذاكرة .
  - 4 1. الطرفان HOLD و HLDA مثل نظيريهما في المعالجات السابقة .
- 15. الطرف PEREQ طرف دخل يسمح للمعالج الحسابى 1387 بطلب بيانات من المعالج 1386 .
- 16. الطّرف BUSY ، طرف دخل يستخدم حينما يكون صفرا لإخبار المعالج i386 بأن المساعد الحسابى i387 مشغول وليس على استعداد الستقبال أو امر أخرى الآن .

- 17. الطرف ERROR ، طرف دخل يستخدمه المعالج الحسابي لإخبار المعالج i386 بأن هناك خطأ قد حدث .
  - 18. الطرف INTR ، طرف دخل يستخدم لطلب المقاطعة .
  - 19. الطرف NMI ، طرف دخل يستخدم لطلب المقاطعة الغير محجوبة .

#### 5-4-17 مسجلات المعالج 80386

شكل (17-8) يبين التركيب الهيكلى والمسجلات الموجودة داخل المعلج 1386. نلاحظ من هذا الشكل أن نفس عدد المسجلات مازال موجودا في هذا المعلج وهذه المسجلات مازالت تؤدى نفس الدور . الجديد هنا هو أن المسجلات في المعالج 1386 تستطيع التعامل مع بيانات مقدارها 8 أو 16 أو 32 بست . حينما نريد التعامل مع هذه المسجلات على أساس 32 بست فإننا نضع هذه المسجلات على أساس 32 بست فإننا نضع ما في الأمر (اختصار لكلمة ممتد Extended) أمام المسجل المراد التعامل معه كما في الأمر التالي :

| EAX EBX       | AH AL<br>BH BL       | AX<br>BX |
|---------------|----------------------|----------|
| ECX           | CH CL                | CX       |
| EDX           | DH DL                | DX       |
| ESP           | SP                   |          |
| EDP           | DP                   |          |
| EDI           | DI                   |          |
| ESI           | SI                   |          |
|               | CS<br>DS<br>ES<br>SS |          |
|               | FS                   |          |
|               | GS                   |          |
|               | مسجلات التجزىء       |          |
| EID           |                      |          |
| EIP<br>EFLAGS | IP IP                |          |
| TALLAGS       | FLAGS                |          |
| عالج 80386    | ئل (17-8) مسجلات الم | Ž.       |

#### MOV EAX,FF340056H

حيث EAX معناها مسجل التراكم الممتد ، وهكذا باقى المسجلات العامة . مسجلات التجزىء EAX تلعب نفس الدور الذى كانت تلعب هم مسجلات التجزىء GS, FS, SS, DS, CS تلعب نفس الدور الذى كانت تلعب هم المعالج 8086 في الحالة الحقيقية real mode ، وتلعب مع المسجلين GS, FS أدوار الضافية في الحالة التخيلية virtual mode .

هناك أيضا المعالج EIP الذي يمثل مؤشر الأوامر الممتد والذي يستطيع التعامل مع 32 بت ، كذلك مسجل الأعلام هنا أصبح ممتدا أيضا حيث أصبح اسمه EFLAGS .

MOV AL, 55H MOV AX, 5544H MOV EAX, 55443322H

### 5-17 الذاكرة المخبأة Cache Memory

مع زيادة نبضات الساعة clock المعالج (33ميجاهرتز المعالج 1386) أصبح زمن تنفيذ أى أمر صغيرا جدا بحيث أصبح أقل من زمن الاتصال بالذاكرة مما سيتسبب في وجود فترات انتظار عند تتفيذ أى أمر يتعامل مع الذاكرة وبالتالي تقليل سرعة المعالج . زمن الاتصال بالذاكرة هو الزمن اللازم لقراءة أو كتابة وحدة بيانات في الذاكرة ، وهذا الزمن يكون عادة في حدود 50 نانوثانية بالنسبة للذاكرة الديناميكية . التغلب على هذه المشكلة تم استخدام أسلوب الذاكرة المخبأة للذاكرة الديناميكية . التغلب على هذه المشكلة تم استخدام أسلوب الذاكرة المحبأة الاتصال بها والتي تصنع خصيصا ، ولذلك فإنها مرتفعة الثمن جدا . كمية هذه الذاكرة تبدأ من 8 كيلوبايت وتصل إلى 512 كيلوبايت وكانت هذه الذاكرة توصل خارج المعالج ، أما الآن فإنها توصل داخل شريحة المعالج نفسه كما سنرى عند عرضنا المعالجات الحديثة مثل عائلة بنتيم Pentium .

من المعروف أن التعامل مع بايتات الذاكرة يكون فى الغالب من أماكن متتابعة فى الذاكرة ، بمعنى أنه عند القراءة أو الكتابة من بايت معينة فإنه فسى الغالب يكون التعامل التالى مع الذاكرة من البايت التالية للبايت السابقة . لذلك عندما يقرأ المعالج بايت معينة من الذاكرة فإنه يحضر هذه البايت وكمية من البايتات

التالية لها ويضعها في الذاكرة المخبأة على أمل أن يكون التعسامل التسالي مسع الذاكرة المخبأة وليس مع الذاكرة الأساسية . ولذلك فإن المعالج عندما يقرأ بايت من الذاكرة فإنه يبحث عن هذه البايت أو لا في الذاكرة المخبأة ، فإن وجدها فإنسه سيقر أها بأقل زمن اتصال ، وإذا لم يجدها فإنه يحضرها من الذاكرة الأساسية وفي نفس الوقت يضعها أيضا في الذاكرة المخبأة مع محاولة ملا الذاكرة المخبأة بالبيانات التالية لهذه البايت . عملية ملأ الذاكرة المخبأة تتم عادة في أثناء فــترات انتظار المعالج . بذلك نضمن أن البايت التي من المحتمل أن يتم قراءتها في المرة القادمة ستكون موجودة في الذاكرة المخبأة . عملية الكتابــة فــي الذاكـرة تكون بنفس الطريقة ، فإن كانت المعلومة المراد إرسالها إلى الذاكرة موجودة في الذاكرة المخبأة فإنه يتم نقلها بأقل زمن اتصال ممكن ، وإذا لم تكن موجودة يتـم تسجيلها والمعلومات التالية لها في الذاكرة المخبأة أولا ثم ترسل إلى الذاكرة الأساسية ، بذلك نضمن أن المعلومة التي ستكتب في الذاكرة في المسرة القادمــة ستكون موجودة غالبا في الذاكرة المخبأة . أي أن عمليات الكتابة أو القراءة منن أو إلى الذاكرة الأساسية تكون من خلال الذاكرة المخبـــاة ، ودون تدخـل مـن المستخدم ، وهذا هو السبب في تسميتها بالذاكرة المخبأة cache لأنها تكون مخبأة عن المستخدم وليس له دخل في التعامل معها أو إدارتها . هذه العملية ثبت أنها تزيد جدا من سرعة التعامل مع الذاكرة اعتمادا على حقيقة أن البيانات التي يتـم التعامل معها في أي وقت سيتم التعامل مع المعلومة التالية لها في المرة القادمة .

# 6-17 المعالج 80486

المعالج 80486 هو معالج عالى التكامل حيث يحتوى بداخله المعالج الحسابى الخاص به 80487 بالإضافة إلى وحدة إدارة الذاكرة وكمية من الذاكرة المخباة الخاص به 80487 بالإضافة إلى وحدة إدارة الذاكرة وكمية من الذاكرة المعالج. لك أن تتخيل مدى كثافة المكونات في هذه الشريحة إذا علمت أنها تحتوى على أكثر من مليون ترانزستور . هذا المعالج يستطيع تنفيذ كل أوامر المعالجات السابقة له من عائلته بدون أي تعديل . بالطبع فإنه لابد أن يحتوى على بعض الأوامر الإضافية نتيجة الإضافات التي تضاف عليه . هذا المعالج يستخدم فكرة مجموعة الأوامر المخفضة ، Reduced Instruction Set Computer, RISC ، والتي ساعدت مع عوامل أخرى في تخفيض الزمن اللازم لتنفيذ الكثير من والدي ساعدت مع عوامل أخرى في تخفيض الزمن اللازم لتنفيذ الكثير من دهدا الوامر إلى نبضة تزامن واحدة . هذا بالإضافة إلى الذاكرة المخبأة مصن علي الداكرة المخبأة على المعالج قائم المعالج تنفيذ البرمجيات الوقت والتي بلغت 336 أو 66 ميجاهر تز ، كل ذلك جعل سرعة تنفيذ البرمجيات بهذا المعالج تبلغ أضعاف سرعتها باستخدام المعالج 1386 .

يوجد المعالج i486 في صورة شريحة شبكية Grid ذات 168 طرف . مسار العناوين لهذا المعالج يتكون من 32 بت ، وكذلك مسار البيانات بالنسبة للتركيب الهيكلي لهذا المعالج فإن مجموعة المسجلات الموجودة فيه هي نفسها مجموعة المسجلات الموجودة فيه من ذلك أن المعالج i486 هو نفسه المعالج i386 مضافا إليه المساعد الحسابي i487 وذاكرة مخبأة مقدارها 8 كيلوبايت .

إننا هنا لن ندخل في تفاصيل أخرى عن هذا المعالج ولا المعالجات التالية ، ولكننا سنكتفى فقط بذكر الجديد أو الإضافة التي قدمتها هذه المعالجات وسنترك الأمر لمن يريد الاستزادة أن يرجع إلى المراجع الموجودة في نهاية الكتاب أو الكتالوجات الخاصة بالمعالج الذي يريد دراسته بالتفصيل .

## 7-17 انسيابية الأوامر Instruction Pipelining

سنقدم هنا فكرة جديدة تزيد سرعة تنفيذ الأوامر بدرجة كبيرة جدا تصل الله المسلم مرات على الأقل . تخيل أن أى أمر يحتاج إلى خمس نبضات تزامن حتى يتم تنفيذه ، بحيث تتم عملية التنفيذ في خلال الخمس نبضات بالخطوات التالية :

Fetch Instruction, FI المراكبة الأمر

2- تشفير الأمر Decode Instruction, DI

Fetch Operand, FO إحضار المعاملات

4-تنفيذ الأمر Execute Instruction, EX

Write Result, WR تخزين النتيجة 5

هذه الخطوات الخمس يمكن تنفيذها بالتتابع على أى أمر ، وفي هذه الحالة فإننا سنحتاج إلى خمس نبضات تزامن لكى تتم عملية إحضار وتنفيذ أى أمر . يمكن إسراع هذه العملية باستخدام فكرة انسياب الأوامر كما هى موضحة في شكل المراح والمنابع من هذا الشكل أن كل أمر تم تقسيمه إلى خمس مراحل بحيث عندما يكون المعالج مشغولا في تتفيذ مرحلة معينة لأمر معين فإن الأمر التالي يتم تنفيذه أيضا في نفس الوقت ولكن في مرحلة أخرى من مراحل التنفيذ . فمشلا عندما يكون الأمر رقم I في مرحلة التخزين WR فإن الأمر راء إلى يكون في مرحلة التنفيذ كل المراد والأمر والأمر عبد الأمر وهكذا . ويكون الأمر ، والأمر والما في مرحلة إحضار المعاملات ، والأمر والأمر أي أنه يكون هناك دائما خمسة أو امر موجودة داخل وحدة التنفيذ كل أمر منها يتنفيذ مرحلة معينة منه على حسب موقعة في تتابع الأوامر داخيل الوحدة . يتم تنفيذ مرحلة الشكل أننا سنحصل من وحدة التنفيذ على أمر وقد تم تنفيذه في نلاحظ من هذا الشكل أننا سنحصل من وحدة التنفيذ على أمر وقد تم تنفيذه في

نهاية كل نبضة تزامن (أمر لكل نبضة) . أى أن سرعة تتفيذ الأوامر قد زادت بمقدار خمس مرات ويمكن زيادتها أكثر من ذلك بزيدادة عدد مراحل تتفيذ الأوامر . أى أن الأوامر تتساب في مراحل التتفيذ فيما يشبه الأنبوبة أو خط الإنتاج وكل أمر يوجد في مرحلة تتفيذ معينة ، ولذلك سميت هذه الطريقة بالانسيابية أو Pipelining.

| رقم<br>الأمر |    | نبضات التزامن |    |    |    |    |    |    |  |
|--------------|----|---------------|----|----|----|----|----|----|--|
| الأمر        | 1  | 2             | 3  | 4  | 5  | 6  | 7  | 8  |  |
| I            | FI | DI            | FO | EX | WR |    |    |    |  |
| I+1          |    | FI            | DI | FO | EX | WR |    |    |  |
| I+2          |    |               | FI | DI | FO | EX | WR |    |  |
| I+3          |    |               | T  | FI | DI | FO | EX | WR |  |
| I+4          |    |               |    |    | FI | DI | FO | EX |  |
| I+5          |    | T             |    | T  |    | FI | DI | FO |  |

شكل (17-9) الانسيابية Pipelining

من الواضح أنه لكى نستفيد من فكرة الانسيابية فإن جميع الأوامر لابد أن يكسون لها نفس الطول أو نفس عدد المراحل ، وكل مرحلة لابد أن تنفسذ فسى نبضسة تزامن واحدة ، فهل هذا محقق فى أوامر المعالجات التي تمت دراستها حتى الآن ؟ بالطبع الإجابة هي لا ، فإن أوامر جميع المعالجات التي درسناها حتى الآن لها أطوال مختلفة وتنفذ فى أعداد مختلفة من نبضات الساعة . وهدذا يسوقنا إلى تقسيم المعالجات إلى نوعين من حيث مجموعة أوامر كل منها .

النوع الأول يسمى المعالجات ذات مجموعة الأوامر المركبة ،

Complex Instruction Set Computers, CISC

النوع الثاني يسمى المعالجات ذات مجموعة الأوامر المخفضة ،

· Reduced Instruction Set Computers, RISC

فى النوع الأول من المعالجات ، CISC ، تكون كمية الأوامر كبيرة جدا ، 300 أمر على الأقل ويكون معظم هذه الأوامر أوامر مركبة . ولذلك فإن مشفر الأوامر Instruction decoder يكون معقدا جدا مما يتسبب أن الإشارة تأخذ وقتا كبيرا في تخلل دائرة المشفر ، ولذلك فإن وحدة التحكم في هذه المعالجات تكون معقدة . أيضا فإن الكثير من الأوامر المركبة يتم تنفيذها بطريقة البرمجيات الصغيرة Microprograms حيث ينفذ أمر الضرب مثلا بتنفيذ برمجية صغيرة

تنفذ عملية الضرب في صورة مجموعة من أوامر الجمع المتكرر ، وهذا بالطبع يستهلك الكثير من الوقت . كذلك فإنه نتيجة اختلاف أطوال الأوامر في هذا النوع من المعالجات فإنه يكون من الصعب استخدام فكرة الانسيابية Pipelining . نتيجة لذلك ظهر التفكير في النوع الثاني من المعالجات RISC حيث يكون كل شيء هنا مخفض ، عدد الأوامر تم تخفيضه حتى أقل من 128 أمر ، وكذلك طرق عنونة الذاكرة Memory addressing تم تخفيضها حيث أن التعامل مع الذاكرة يستهلك الكثير من الوقت .

مع بساطة عدد الأوامر فإن مشفر الأوامر ، وكذلك وحدة التحكم سيكونان أكـــثر بساطة مما سيوفر الكثير من وقت التنفيذ ، كذلك فإن تخفيـــض عــدد الأوامـر سيقتصر على الأوامر ذات الأطوال الواحدة بقدر الإمكان والتي يمكن تنفيذها في نفس عدد المراحل مما سيسهل استخدام طريقة الانسيابية Pipelining في تنفيـــذ هذه الأوامر . مع تخفيض عدد الأوامر وبساطتها في المعالجــات RISC أمكـن الاستغناء وبدرجة كبيرة على استخدام البرمجيات الصغيرة في تنفيـــذ الأوامـر حيث أمكن استخدام دوائر مبنية Hardware لتنفيذ هذه الأوامر مما وفــر الكثـير من وقت التنفيذ أيضا . كما رأينا فإن أنظمة RISC تتمتع بالكثير من الممــيزات مما جعل معظم المعالجات ابتداء من المعالج 80486 تقريبا يأخذ بــــهذه الفكـرة وينفذها ، حيث أصبحت كل الأوامر تقريبا تنفذ في نبضة تزامن واحدة .

في أثناء تنفيذ بعض الأوامر في أي برنامج تنتج هناك بعض النتائج المرحلية التي يحتاجها البرنامج بعد قليل ، ولكن بما أن عدد المسجلات داخـــل المعالج يكون محدودا فإن المعالج يضطر الإرسال هذه النتائج المرحلية إلى الذاكرة حيث يتم استدعاؤها مرة ثانية عند الحاجة إليها ، وهذا بالطبع يستهلك الكثير من الوقت . هذه المشكلة يمكن التغلب عليها بدرجة كبيرة بزيادة عدد المسجلات ذات الأغراض العامة داخل المعالج بحيث يمكنها أن تستوعب هذه النتائج المرحلية . معظم معالجات RISC تحتوى على عدد كبير من المسجلات تصل إلى 32 مسجلا وتسمى هذه المجموعة بملف المسجلات Register file . هنا يمكن أن نسأل السؤال التالي: هل يمكن الاستغناء عن الذاكرة المخياة Cache memory باستخدام ملف مسجلات مع زيادة عدد المسجلات فيه ؟ الإجابة علي هذا السؤال هي لا . إن زيادة عدد المسجلات بدرجة كبيرة يجعل من الصعب عنونتها ويكون التعامل مع الذاكرة المخبأة في هذه الحالمة أسهل . إن الحد الفاصل بين عدد المسجلات الكبير والصغير غير واضح تماما ولكن ثبت بالتجربة أن 32 أو 64 مسجلا بالإضافة إلى كمية من الذاكرة المخبأة يكون لـها أفضل تأثير على سرعة أداء المعالج . شكل (17-10) [Tabak 1995] يبين علاقة بين كمية المسجلات المستخدمة مع كمية الذاكرة المخبأة على أداء المعللج من حيث سرعة تتفيذ مجموعة من أو امر النداء على البرامج الفرعية . من هـذا الشكل نلاحظ كيف أن زيادة عدد المسجلات من 32 إلى 64 مسجلا كان له تأثيرا كبيرا على زيادة السرعة ، ولكن معدل هذا التحسين كان قليلا جدا مع زيادة عدد المسجلات عن 64 مسجلا ، ولذلك فإنه ثبت بالتجربة وكما هو واضح من هدذا الشكل أن 64 مسجلا مع 256 كيلوبايت من الذاكرة المخبأة يعطي أحسن أداء للمعالج .



من الأسباب المهمة التى تجعل من الصعب الاستغناء عن المسجلات العامة بالذاكرة المخبأة أن المسجلات العامة يمكن استخدامها بواسطة الميرمج وتكون دائما تحت تصرفه ، بينما فى حالة الذاكرة المخبأة فابن المبرمج لا يملك أى سيطرة عليها ولا يستطيع التعامل معها على الإطلاق والمتحكم فى تشغيلها فقط هو وحدة التحكم بالمعالج . لذلك لابد من وجود ملف مسجلات مع كمية من الذاكرة المخبأة للحصول على أحسن أداء للمعالج .

وعلى ذلك يمكن تلخيص مجموعة الخواص المميزة لأى حاسب RISC فيما يلى: 1. جميع الأوامر (أو 80% على الأقل) تنفذ في نبضة تزامن واحدة .

- 2. جميع الأوامر لها نفس الطول (عدد البايتات لكل أمر) ، وفي الغالب يتكــون كل أمر من 4 بايت (32 بت) .
  - 3. عدد مخفض من الأوامر لا يتعدى 128 أمر.
- 4. عدد مخفض من طرق التعامل مع الذاكرة Addressing modes لا يزيد عن 4 طرق .
  - 5. كل الأوامر فيما عدا القليل منها يتعامل مع المسجلات فقط.
- 6. وحدة التحكم تكون مصممة باستخدام الدوائس المبنيسة Hardwired وليسس باستخدام البرمجيات الصغيرة Microprograms .
- 7. عدد كبير من المسجلات العامة الأغراض (32 مسجل على الأقل) في ملف مسحلات .

#### ومن مميزات معالجات RISC ما يلى :

- 1. البناء باستخدام تكنولوجيا التجميع عالى الكثافة جدا VLSI نتيجة لما يلى:
- نتيجة تبسيط وحدة التحكم ثقل مساحته بدرجة كبيرة ، ويكفى أن نعلم أن وحدة التحكم في معالجات CISC تشغل تقريبا 50% من مساحة الشريحة بينما تشغل فقط حوالي 10% من مساحة الشريحة في حالة المعالجات RISC .
- نتیجة صغر مساحة وحدة التحكم على الشریحة یمكن إضافة ملف مســجلات یحتوی عددا أكبر من المسجلات.

#### 2. زيادة سرعة الحساب نتيجة لما يلى:

- إمكانية استخدام الانسيابية Pipelining في تنفيذ الأوامر فإن المعالج يكون مشغو لا دائما مما يزيد من سرعته.
- تصميم وحدة التحكم باستخدام الدوائسر Hardwired بدلا من البرمجيات الصغيرة Microprograms .
  - وجود ملف المسجلات يقلل التعامل مع الذاكرة .
- 3. بساطة الأوامر المستخدمة وتخفيض عددها ، وبساطة تصميم وحدة التحكيم بالطبع سينعكس على تكلفة تصميم شريحة المعالج مما سينعكس على سعر المعالج .

من عيوب المعالجات RISC أن تخفيض عدد الأوامر سيضطر مصمموا البرامج الى استخدام عدد أكثر من الأوامر لتنفيذ نفس البرنامج مما سيؤدى إلى كبر حجم البرنامج وكبر حجم الذاكرة التى يشغلها . لذلك فإنه مسن المتوقع أن برامج معالجات RISC تكون أطول بحوالى 30% من برامج معالجات CISC .

### 8-17 سلسلة معالجات بنتيم Pentium Processors

بعد المعالج 80486 وفي بداية التسعينات ، 1993 ، ظهرت سلسلة المعالجات بنتيم pentium ، وسنطلق علبها سلسلة لأنها خضعت لتطورات سريعة جدا ومتلاحقة . هذه المعالجات تستخدم طريقة القوائم المخفضة RISC واثنان من الانسيابات Pipelines لزيادة سرعة تنفيذ الأوامر حيث وصلت سرعة تنفيذ الأوامر فيه إلى Pipelines (Million Instruction Per Second) للمعالج الدني يعمل بنبضات ساعة مقدارها 200 ميجاهرتز بدلا من MIPS المعالج المعالج المفاتم منافح منبضات ساعة مقدارها 66 ميجاهرتز . من أهم خواص هذا المعالج ما يلى :

1. اثنان من الانسيابات Pipelines واحدة لتنفيذ الأوامر التي نتعامل مع البيانات الصحيحة Integer Pipelines والأخرى لتنفيذ الأوامر التي تتعامل مع البيانات الحقيقية Floating Point Instructions .

2. خاصية توقع أو امر التفريع مثل القفز والنداءات على البرامج الفرعية ، والتي يكون لها دخل كبير في إسراع التعامل مع الذاكرة المخبأة .

3. ذاكرة مخبأة خاصة بالتعامل مع البيانات ، وأخرى خاصية بالتعامل مع الأوامر .

4. مسار بیانات خارجی 64 بت .

5. حالة تشغيل جديدة وهي حالة توفير القدرة Power saving mode .

شكل (17-11) يبين رسما صندوقيا لهذا المعالج حيث نلاحظ وجبود وحدتى الذاكرة المخبأة وحدتى الانسياب المنفصلتين حيث بهذه الطريقة يمكن تنفيذ أمرين في نفس الوقت على التوازى . أحد إصدارات هذا المعالج يوجد فى شويحة ذات 296 طرفا فى الشكل الشبكى وتسحب تيارا مقداره 4 أمبير للمعالج 133 ميجاهرتز . هذا المعالج له 53 طرفا كلها تمثل القدرة من و 53 طرفا تمثل الأرضى . هذا العدد الكبير من الأطراف الخاصة بالقدرة يستخدم لتخفيض الحرارة المنبعثة . لاحظ از دواجية وحدة الانسياب ووجود وحدة جديدة APIC فى وحدة تحكم فى المقاطعة قابلة للبرمجة (Interrupt Controller بنتيم تتحكم فى المعالج بنتيام تتفيذ أمرين فى نفس دائرتى الانسياب حيث فى الأحوال العادية يستطيع المعالج تنفيذ أمرين فى نفس الوقت كما ذكرنا . يستطيع المعالج بنتيام تنفيذ عمليات البيانات الحقيقية Floating

Point أسرع من المعالج 1486 حوالى 10 مرات نتيجة استخدام دوائر مبنية Hardware لتنفيذ عمليات الضرب والقسمة بدلا من البرمجيات الصغيرة. يحتوى المعالج بنتيم على بعض الأوامر المركبة التي تعمل باستخدام البرمجيات الصغيرة وبالذات الأوامر المنقولة من المعالجات السابقة ، ولذلك فإن هذا المعالج متوافق تماما مع كل ما سبقه من معالجات بحيث أن كل أوامر المعالجات السلبقة يمكن تنفيذها عليه مع الاستفادة بوحدتى الانسياب الموجودة فيه .



المدى العنوانى للإدخال والإخراج I/O Address Space للمعالج بنتيسم يبلغ 64 كيلوبايت للبوابات ذات 16 بت ، أو 32 كيلوبايت للبوابات ذات 16 بت و 16 كيلوبايت للبوابات ذات 32 بت حيث يمكن للمعالج التعامل مع كل هذه الأنواع أو مع بعضها .

الذاكرة المخبأة تكون غالية الثمن كما ذكرنا لأنها تتميز بصغر زمن الاتصال بها وتتقسم هذه الذاكرة إلى مستوبين من حيث اتصالها بالمعالج . فهناك الذاكرة المخبأة ذات المستوى الأول Level 1 والتي يرمز لها بالرمز L1 . هذه الذاكرة يتم بناؤها داخل شريحة المعالج نفسه وتكون كميتها صغيرة حوالي 8 أو 16 كيلوبايت في العادة .

المستوى الثانى من الذاكرة المخبأة Level 2 ويرمز لها بالرمز L2 ، ويتم بناؤها خارج شريحة المعالج وتكون امتداد لذاكرة المستوى الأول . أى أن البيانات تتنقل منها إلى ذاكرة المستوى الأول في حالة القراءة ، ومن ذاكرة المستوى الأول الأول اليها في حالة الكتابة وليس للمستخدم أى سيطرة عليها . كمية هذه الذاكرة تكون كبيرة في العادة حيث تبلغ 512 كيلوبايت .

### 9-17 المعالج بنتيم برو Pentium Pro Processor

لقد كان التطور التالى فى عائلة بنتيم هو المعالج بنتيم برو الذى تميز باحتوائه على كل ذاكرة المستوى الثانى المخبأة ، أى أنه يحتسوى علسى 512 كيلوبايت ذاكرة مخبأة من المستوى الأول داخل نفس شريحة المعالج . لكى تتصور مدى كثافة المكونات على شريحة هذا المعالج فإنه يحتوى على خمسة ونصف مليون ترانزستور كلها مجمعة على شريحة تبلغ مساحتها 7.26 سم × 6.25 سم . هذه الشريحة تستهلك قدرة كهربية مقدار ها 38 وات (12 أمبير تقريبا عند 3.3 فولت).

يحتوى المعالج بنتيم برو على 3 وحدات انسياب Pipeline كل منها تتكون مـــن 12 مرحلة ، كما يحتوى على وحدة معالجة البيانات الحقيقيـــة Floating Point . Unit, FPU

لقد صدر المعالج بنتيم برو في شريحة شبكية متداخلة الأرجل Staggered Pin . شكل (17-12) يبين رسما صندوقيا لهذا المعالج . يتضبح لنا من هذا الشكل أن مسار البيانات يتكون من 64 بت ، بينما مسار العناوين يتكون من 36 بت . هناك أيضا وحدة مواجهة المسارات Bus Interface Unit والتي تمثل حلقة الوصل بين المسارات الخارجية ووحدتى الذاكرة المخبأة

الداخلية ، حيث الوحدة الأولى تمثل وحدة ذاكرة مخبأة للبيانات ، والوحدة الثانيـــة تمثل ذاكرة مخبأة للأوامر وكل منهما من المستوى الأول وتبلغ 8 كيلوبايت .



الجديد أيضا أن كل واحدة من وحدتى الذاكرة المخبأة السابقتين لها مسار بيانات خاص لقراءة البيانات ومسار آخر للكتابة بحيث يمكن القراءة والكتابة فى نفسس الوقت من أى واحدة فى نفس نبضة التزامن . تمثل وحدة مواجهة المسارات أيضا حلقة الوصل بين المسارات الخارجية ووحدة الذاكرة المخبأة الثالثة .

تقوم وحدة إحضار الأوامر Instruction Fetch, IF بإحضار الأوامر من الذاكرة المخبأة للأوامر إلى مشفر الأوامر السذى يحتوى على 3 وحدات انسياب Pipelining تعمل على التوازى ، اثنان منها لتشفير الأوامر البسيطة ، والتسالث لتشفير الأوامر المركبة CISC والتى تتطلب برمجيات قصيرة لتنفيذها .

يحتوى المعالج بنتيم برو على 40 مسجلا عاماً تقوم وحدة جدول المسجلات العامة Register Table loave المسجلات العامة Register Table المعروفة من المعالجات السابقة . يوضح هذا الشكل أيضا احتواء هذا المعالم المعروفة من المعالجات السابقة . يوضح هذا الشكل أيضا احتواء هذا المعالج على خمس وحدات التنفيذ الأوامر ، اثنان منها لتنفيذ الأوامر ذات البيانات الصحيحة INTI والحقيقية FPUII و POIII و POIII و POIII و POIII و POIII و POIII و اثنان التنفيذ الأوامر ذات البيانات الصحيحة INTI والمحداث تعمل منفصلة وغير معتمدة على بعضها مما يمكنها من تنفيذ خمسة أوامر في نفس الوقت على التوازى وفي نفس نبضة التزامن الواحدة . بالطبع لا يخلو الأمر من بعض الأوامر الشاذة التي تحتاج لمعاملات خاصة و هذه تحل يخلو الأمر من بعض الأوامر الشاذة التي تحتاج لمعاملات خاصة و هذه تدل والقفز . آخر وحدة العزل Poir unit هي وحدة المقاطعة المتقدمة القابلة البرمجة مشاكل أوامر الشكل هي وحدة المقاطعة المتقدمة القابلة البرمجة المتعدة Advanced Programmable Interrupt Controller, PIC ون هذا النوع دون الاحتياج لأي إضافات .

بذلك نكون قد وقفنا على جميع المعالجات بجميع أنواعها ، ونكون قد تأكدنا من أن فكرة المعالج الأساسية لم تتغيير ابتداء من المعالجات 8 بت وانتهاء بالمعالجات 64 بت .

#### 10-17 تمــارين

1. ما هو مقدار الذاكرة التي يمكن أن يتعامل معها كل من المعالجات التالية:

- المعالج 8086
- المعالج 80186
- المعالج 80286
- المعالج 80386
- المعالج 80486

- المعالج بنتيم
- المعالج بنتيم برو
- 2. كم عدد بتات مسار البيانات في كل المعالجات السابقة ؟
- 3. اشرح نظام الذاكرة في كل واحد من المعالجات السابقة وكيفية تتشيط البنكات المختلفة في كل حالة ؟
- 4. اشرح نظام الإدخال والإخراج في كل من المعالجات السابقة وكيفية تتشيط البنكات المختلفة في كل حالة أيضا ؟
  - 5. ما هي وظيفة الطرف  $\overline{BS16}$  في المعالج 80386  $\ref{BS16}$
- 6. ما هي الذاكرة المخبأة cache memory ؟ وما هــو أول معالج بـدأ فــي
   استخدامها ؟ وما مقدارها في كل معالج من المعالجات التي استخدمتها ؟
- 7. اشرح المقصود بملف المسجلات Register file ؟ وما هو أول معالج بدأ في استخدامه ؟ وما هو عدد المسجلات في كل معالج من المعالجات التي استخدمت هذه الفكرة ؟
- 8. ما هو الفرق بين الذاكرة المخبأة وملف المسجلات ؟ وهل يمكن الاستغناء عن أى منهما على حساب الآخر ؟
- 9. اشرح فكرة الانسياب Pipelining ؟ وما هي المعالجات التي تستخدم هذه الفكرة ؟
- 10. ما هو المقصود بالحاسبات ذات القائمة المخفضة RISC ؟ وعلى أى شيء تم التخفيض ؟
  - 11. هل هناك علاقة بين فكرة تخفيض الأوامر RISC والانسياب ؟
    - 12. اذكر خصائص ومميزات وعيوب الحاسبات RISC ؟
      - 13. ما هو الفرق بين المعالجين بنتيم وبنتيم برو؟
- 14. إذا طلب منك تصميم دائرة تتحكم في إشارة مرور في تقاطع معين ، فأى المعالجات التي درستها تختار ؟
- 15. ما رأيك في الاستغناء عن دراسة المعالجات 8 بت والاكتفاء بدراسة أخر الأجيال منها وهو المعالج بنتيم برو مثلا ؟

# $1 \dots$ الملحق الأول

# الحساب الثنائي Binary Arithmatic

#### مقدمة

لقد رأينا في الفصل السابع كيفية إجراء الجمع الثنائي والطرح الثنائي باختصار شديد وقد كان التركيز الكلي على الدوائر التي تفي بهذه الأغراض ، ولكن تبقي حتى الآن بعض الأسئلة التي مازالت تحتاج إلى إيضاح ومنها كيف يتعامل المعالج مع الأرقام السالبة ؟ وكيف يميز بين رقم سالب وآخر موجهب ؟ وأنا كمبرمج كيف أعرف إذا كانت النتيجة سالبة أو موجبة ؟ وماذا عسن عمليات الضرب والقسمة ؟ كل هذه الأسئلة سنجيب عنها في هذا الملحق إن شاء الله .

### عمليات الجمع والطرح انظر إلى عمليات الجمع الثنائي التالية:

| BCD         | عشرى   | BCD         | عشري |  |
|-------------|--------|-------------|------|--|
| 0010 0101   | 25     | 0101 0101   | 55   |  |
| 0011 0001 + | . 31 + | 0100 0100 + | 44 + |  |
| 0101 0110   | 56 .   | 1001 1001   | 99   |  |

نلاحظ في هذين المثالين التطابق التام في نتيجة الجمع في كلا النظامين العشرى والعشرى المكود ثنائيا BCD. الآن انظر إلى عمليتي الجمع التاليتين:

| DCB         | عشرى | BCD         | عشری |
|-------------|------|-------------|------|
| 0010 1001   | 29   | 0101 0101   | 55   |
| 0010 0010 + | 22 + | 0011 1000 + | 38 + |
| 0100 1011   | 51   | 1000 1101   | 93   |

نلاحظ فى المثالين السابقين عدم التطابق بين الصورة العشرية والصورة الثنائية ولكن الظريف فى الأمر أننا يمكن أن نحصل على التطابق المطلوب بمجرد إضافة الرقم 6 (0110) إلى النتيجة كما يلى:

| DCB            | عشرى | BCD         | عشرى |
|----------------|------|-------------|------|
| 1001 0010      | 29   | 0101 0101   | 55   |
| 0010 0010 +    | 22 + | 0011 1000 + | 38 + |
| 1011 0100(خطأ) | 51   | 1000 (خطأ)  | 93   |
| 0110 +         |      | 0110 +      |      |
| 0001 (صح)      |      | 1001 (صبح)  |      |

من ذلك نخرج بنتيجة مهمة وهى أنه فى حالة جمع رقمين كل منهما 4 بتات فإنه إذا كانت النتيجة أقل من أو تساوى 9 فإن هذه النتيجة تكون متطابقة مع النظام العشرى ولا تحتاج لعملية ضبط adjust. أما إذا كانت النتيجة أكبر من 9 أو كان هناك حمل من الخانة الثالثة (الأخيرة) فإنه للحصول على النتيجة فى الصورة العشرية فلابد من عملية ضبط باضافة الرقم 6 (0110) للنتيجة ، لزيادة التأكيد على ذلك انظر للأمثلة التالية :

أما في حالة جمع رقمين كل منهما 8 بتات فإن نفس النتيجة السابقة تطبق على كل نصف من النتيجة على حده ، أى أنه إذا كان النصف الأول من النتيجة أكبر من 9 أو كان هناك حمل من الخانة الثالثة إلى الخانة الرابعة (أى أن علم الحمل البيني HCF يساوى واحدا) فإنه يجب إضافة الرقم 6 (0110) إلى النتيجة كعملية ضبط . وأما إذا كان النصف الثاني من النتيجة أكبر من 9 أو حصل حمل من الخانة السابعة (أى علم الحمل يساوى واحد) فإنه يجب إضافة الرقم 60H (0110 (0000) إلى النتيجة كعملية ضبط للحصول على النتيجة في الصورة العشرية . الأمثلة التالية توضح ذلك :

إن عملية إضافة الرقم 6 أو 60H إلى النتيجة تسمى عملية الضبط العشرى وهذه العملية يقوم بها الكثير من المعالجات بناء على الأمــر DAA والــذى يعنى Dicimal Adjust accumulator after Addition أى ضبط المركم عشريا بعد عملية الجمع.

يمكن إجراء نفس عملية الضبط السابقة بعد عملية الطرح ، الإختلاف هو أنسا نطرح الرقم 6 من النتيجة إذا كان النصف الأول منها أكبر من 9 أو كان علم الحمل البيني HC يساوى واحدا ، ونطرح الرقم 60H من النتيجة إذا كان النصف الثانى منها أكبر من 9 أو كان علم الحمل CF يساوى واحدا ، الأمثلمة التاليمة توضح ذلك :

لننسى كون النتيجة يجب أن تكون سالبة أو موجبة الآن ونعلم أن عملية طرح الرقم 6 أو 60H من النتيجة يقوم بها الكثير من المعالجات بناء على الأمو DAS أي Decimal Adjust accumulator after Subtraction والتي تعنى ضبط المركم عشريا بعد عملية الطرح.

### تمثيل الأرقام السالبة في النظام الثنائي

فى النظام العشرى نستطيع تمييز الأرقام السالبة بوضع إشارة (-) قبل الرقم كما نستطيع تمييز الأرقام الموجبة بوضع الإشارة (+) أمامه . أما فى النظام الثنائى حيث الواحد والصفر هما الشكلان الوحيدان المتاحان للاستخدام فلابد وأن يكون هناك وسيلة لتمثيل الأرقام السالبة والموجبة . ولقد تم التعارف على أن تكون آخر بت فى الرقم تمثل إشارة ذلك الرقم وتم التعارف أيضا على أنه إذا كسانت آخر بت تساوى صفرا فإن ذلك الرقم يكون موجبا وإذا كانت آخر بت تساوى واحدا فإن ذلك الرقم يكون سالبا . وإليك بعض الأرقام السالبة والموجبة على حسب التعارف السالبة والموجبة على حسب التعارف السالبة والموجبة على

|     |           | -       |
|-----|-----------|---------|
|     | ة الإشارة | خانا    |
|     |           |         |
| +7  | 0         | 0000111 |
| +46 | 0         | 0101110 |
| +64 | 0         | 1000000 |
| -12 | 1         | 1110100 |
| -46 | 1         | 1010010 |
|     |           | ı       |

#### المتمم الثنائي

لتسهيل العمليات الحسابية ، وبالذات عمليات الطرح , في ظل هذا التعارف السابق فقد تم استخدام نظام المتمم الثنائي لتمثيل الأرقام السالبة . المتمم الثنائي لأي رقم ثنائي يمكن الحصول عليه بعكس كل بت في الرقم (جعل الواحد صفوا

والصفر واحدا) ثم إضافة واحد لنتيجة هذا العكس . هذا المتمم الثنائي للرقم يمثل الرقم سالبا . الأمثلة التالية توضح ذلك :

الرقم 7+ يمثل ثنائيا بالرقم 11 00000 حيث نلاحظ أن آخر بت تساوى صفرا دلالة على أن هذا الرقم موجب ، انن كيف نمثل الرقم 7- ؟

للحصول على الرقم 7- الثنائي نتبع الخطوات التالية:

الرقم 7+ هو 00000111 أعكس الرقم 11111000 أضف واحدا 11111001

هذه النتيجة الأخيرة (11111001) تمثل الرقم 7- في النظام الثنائي .

لاحظ أنه في ظل تخصيص الخانة الأخيرة للإشارة أصبحت قيمة الرقسم ممثلة فقط بسبعة (بتات) ، أي أن قيمة الرقم قد نقصت حيث كانت قيمته تتراوح بيسن الصفر و 255 قبل اعتبار الخانة الأخيرة كخانة إشارة ، أما في ظل اعتبار الخانة الأخيرة كخانة إشارة مقل اعتبار الخانة الأخيرة كخانة إشارة فلقد أصبحت قيمة الرقم تتراوح بين الصفر و +127 للأرقام الموجبة (البت الثامنة صفر) ، وتتراوح قيمة الرقسم بيسن -1 و -128 للأرقام السالبة ( بث الإشارة واحد) . وعلى ذلك يمكن كتابة هذه الأرقام كما يلى:

01111111 +127 01111110 +126 01111101 +125 00000001 +1 0 00000000 111111111 -1 -2 111111110 10000001 -12710000000 -128

افترض أن أمامك رقما وتريد معرفة قيمة هذا الرقم وهل هو سالب أم موجب؟ في هذه الحالة عليك أو لا النظر إلى خانة الإشارة فاذا كانت صفرا فإن هذا الرقم موجب وتحدد قيمته بباقى الخانات السبعة . أما إذا كانت خانة الإشارة تحتوى واحدا فإن ذلك يعنى أن هذا الرقم سالبا وتحدد قيمته بعد حساب المتمسم التنائى للرقم . كمثال على ذلك افترض أن لديك الرقم 11111001 ، هذا الرقم سالب لأن آخر خانة تساوى واحدا ، وللحصول على قيمة هذا الرقم نحسب المتمم الثنائى له كالتالى :

الرقم 11111001 اعكس 00000110 أضيف واحدا 00000111 إذن هذا الرقم هو 7-

إليك الآن بعض الأمثلة على عمليات الجمع والطرح للأرقام ذات الإشارة:

لاحظ أننا نتعامل في النظام الثنائي وليس النظام الستعشري .

فى الأمثلة السابقة كنا نتعامل فى النظام العشرى أو النظام الثنائى ، ماذا سيكون الموقف عند التعامل مع النظام الستعشرى الشائع الاستخدام فى الكثير من أنظمة المعالج . إليك بعض الأمثلة التى توضح ذلك :

من ذلك نرى أن عملية تمثيل الأرقام السالبة بالمتمم الثنائي للرقم هي نفسها فـــى أي من النظامين العشري أو الستعشري ، كل ما هناك هو ملاحظة الفسرق فسي كينية وضع الرقم في صورته الثنائية . إن الأمثلة السابقة توضح لنا أن عملية الطرح ما هي إلا عملية جمع للمطروح منه مع المتمم الثنائي للمطروح وذلك ما تقوم به عادة دوائر المعالج التي تقوم بنتفيذ عملية الطرح كما رأينا في الفصل

00001010

#### الضرب والقسمة ثنائيا

بمكن إجراء الضرب الثنائي بأكثر من طريقة أولها هي طريقة الضرب في النظام العشرى والتى نعرفها جميعا منذ الصغر حيث يتم ضرب الخانة الأولىي من المضروب في المضروب فيه وتدون النتيجة ، ثم يتم ضرب الخانــة الثانيــة من المضروب في المضروب فيه وتدون النتيجة تحت النتيجة السابقة ولكن تـزاح لليسار بمقدار خانة ، وهكذا يتم ضرب جميع خانات المضروب في المضــروب فيه وفي كل مرة تدون النتيجة تحت النتيجة السابقة بعد إزاحتها بمقدار خانسة واحدة ، وفي النهاية يتم جمع جميع النتائج السابقة كما يلي :

من الطرق الأخرى للضرب استخدام طريقة الجمع المتكرر حيث في المثال السابق مثلا نقوم بجمع العدد 11مع نفسه 9 مرات . من عيوب هذه الطريقة أنها تكون بطيئة بالذات في حالة ضرب الأرقام الكبيرة ، فمثلا في حالة ضرب الرقمين 165 في 99 سنقوم بجمع الرقم 165 مع نفسه 99 مسرة وذلك بالطبع يتطلب الكثير من الوقت .

فى المثال السابق (11x9) نرى أن نتيجة ضرب أى خانة من المضروب في المثال السابق (11x9) نرى أن نتيجة ضرب أى خانة من المضروب فيه تكون إما صفرا أو المضروب فيه نفسه حيث أن هذه الخانة تكون إما صفرا أو واحدا . يمكن الاستفادة من ذلك فى استنتاج طريقة أخرى للضرب أسرع وأنسب من الطريقتين السابقتين كمنا سنرى فى المثال التالى (13x13=169):

|                                                          | 1101     |
|----------------------------------------------------------|----------|
|                                                          | 1101 ×   |
| طالما أن البت الأولى من المضروب 1 كتبنا المضروب فيه      | 1101     |
| كما هو.                                                  |          |
| ثم أزحنا النتيجة السابقة لليمين بمقدار خانة واحدة .      | 01101    |
| طَالما أن البت الثانية من المضروب 0 لم نفعل شي فقط أزحنا | 001101   |
| النتيجة السابقة لليمين بمقدار خانة .                     |          |
| طالما أن الخانة الثالثة من المضروب 1 جمعنا المضروب فيه   | 001101   |
| على النتيجة السابقة فنحصل على النتيجة التالية :          | 1101 +   |
|                                                          | 1000001  |
| ثم أزحنا النتيجة السابقة ناحية اليمين بمقدار خانة .      | 01000001 |
| - 1                                                      |          |
| طالما أن البت الرابعة في المضروب 1 نجمع المضروب فيه      | 01000001 |
| على النتيجة السابقة فنحصل على النتيجة النهائية التالية : | 1101 +   |
| 169                                                      | 10101001 |

أى أن هذه الطريقة تتلخص فى أننا نضرب الخانة الأولى من المضروب فى المضروب فيه ثم نزيح النتيجة ناحية اليمين بمقدار خانسة ، وإذا كانت الخانسة الثانية صفرا فلا نعمل شيئا سوى الإزاحة لليمين بمقدار خانة ، وإذا كانت واحدا نجمع المضروب فيه مع النتيجة السابقة ثم نزيح نتيجة الجمع السابقة خانة وننظر فى الخانة الثالثة من المضروب ، وهكذا . نلاحظ أن هذه الطريقة أسرع بكثير من الطرق السابقة كما نلاحظ أن النتيجة النهائية للضرب تشغل عددا من البتات يساوى مجموع عدد بتات المضروب والمضروب فيه .

لإجراء عملية القسمة الثنائية نتبع نفس الخطوات التي اتبعناها في إجراء عمليات الجمع الثنائي ، سوى أننا نستخدم الطرح المتكرر بدلا من الجمع المتكرر كما في حالة الجمع ، أو نستخدم الطرح ثم الإزاحة ناحية اليسار بدلا مسن الجمع ثم الإزاحة ناحية اليمين كما في حالة الضرب .

#### مراجع الكتاب

- 1. The MFA microcomputer training kit manuals, 1986.
- 2. Heathkit manual for the microprocessor trainer model ET-3400, 1981.
- 3. Ramesh S. Gaonkar, "Microprocessor architecture, programming and applications with the 8085/8080A." Wiley Eastern Limited, 1986.
- 4. Douglas V. Hall "Microprocessors and digital systems" Mcgraw Hill Book company, 1983.
- 5. Kathe Spracklen "Z-80 and 8080 assembly language programming" Hayden Book Company, Inc. 1979.
- 6. Charles K. Adams "Master handbook of microprocessor chips" TAB Books Inc. 1981.
- 7. David F. Stout "Microprocessor applications handbook" McGraw Hill Book Company, 1985.
- 8. James W. Coffern "Z-80 Applications" ترجمة الدار العربية للعلوم 1988.
- 9. Lance A. Lventhal "6800 assembly language programming" Osborne & Associates Inc. 1978.
- 10. Joseph J. Carr "Microprocessor Interfacing" TAB Books Inc. 1982.
- Frank P. Tedeschi & Robert Colen "101 projects for the Z-80" TAB Books Inc. 1983.
- 12. Hermann Schmid "Electronic analog/digital conversions" Van Nostrand Reinhold Company, 1970.
- 13. Micro-tech Publication "Microprocessor Data Hand Book" 1991
- 14. Michael Thorne "Programming the 8086/8088 for the IBM PC and Compatables" The Benjamin P. Company 1986
- الطبعة الأولى 1991 "البرمجة بلغة التجميع" د. عوض منصور 15.
- 16. Barry B. Brey "The Intel Microprocessors 8086, 80186, 80286, 80386, 80486" Maxwell International 1991.
- 17. Hans-Peter Messmer "The Indispensable PC Hardware Book" Addison- Wesley 1997.
- 18. Daniel Tabak "Advanced Microprocessors" McGraw Hill Inc. 1995

# المالعات الدقيقة

## Microprocessors

تأليف / د. محمد إبراهيم العدوى

ن مذا الكتاب

ما هر الميكروبروسيسسور (المعالج الدقيق)؟ أين يقع المعالج في الميكروكومبيوتر؟ كيف يمكن برمجته؟ كيف يمكن توصيله مع الذاكرة؟ كيف يمكن إدخال بيانات إليه، وكيف يمكن إخراج بيانات منه؟ كيف يمكن استخدام المعالج كعنصر أساسي في دوائر التحكم مثل التحكم في درجات الحرارة والضغط وإشارات المرور وغير ذلك؟ ما هو الميكروكومبيوتر ذو الكارت الواحد؟ ما هي البرامج الفرعية؟ كيف يمكن مقاطعة الميكروبروسيسيور؟ كل هذه الأسئلة وأكثر بجبب عنها هذا الكتاب في أسلوب سهل وأفكار متدرجة خالية من التعقيد ومن يجبب عنها هذا الكتاب في أسلوب سهل وأفكار متدرجة خالية من التعقيد ومن المعالج أمثلة وتمارين كثيرة مطبقة على أشهر المعالجات ذات 8 بت وهي المعالج intel معالج قاله أسلوب المعالجات ذات 8 بت وهي المعالج intel 8086 ولما الكتاب عند هذا الحد بل قدم المعالجات الأخرى مثل المعالجات 80186 ولما الكتاب عند هذا الحد بل قدم المعالجات الأخرى مثل المعالجات 80186 ولم 80386 و 80486 و 80486 وحتى الأجبال المتأخرة من عائلة يشبم المعالجات



### IHCI

**FIGNAL HOUSE FOR CULTURAL INVESTMENTS** 

CAIRO - EGYPT

ISBN: 977-282-076-5